:root {
  --ysj-bg: #f5f7f6;
  --ysj-bg-deep: #eef3f1;
  --ysj-surface: #ffffff;
  --ysj-surface-soft: #f9fbfa;
  --ysj-surface-tint: #eff7f4;
  --ysj-line: #d8e6e2;
  --ysj-line-strong: #bfd7d0;
  --ysj-text: #10231f;
  --ysj-text-soft: #31453f;
  --ysj-muted: #667871;
  --ysj-brand: #067467;
  --ysj-brand-strong: #05584f;
  --ysj-brand-soft: #e7f7f2;
  --ysj-gold: #a16207;
  --ysj-gold-soft: #fff7df;
  --ysj-red: #b91c1c;
  --ysj-red-soft: #fff1f1;
  --ysj-blue: #075985;
  --ysj-blue-soft: #eef7ff;
  --ysj-radius: 8px;
  --ysj-radius-sm: 6px;
  --ysj-shadow: 0 12px 30px rgba(17, 37, 33, 0.055);
  --ysj-shadow-sm: 0 6px 16px rgba(17, 37, 33, 0.045);
  --ysj-shadow-flat: 0 1px 0 rgba(16, 39, 36, 0.04);
}

html {
  background: var(--ysj-bg);
}

body {
  background:
    linear-gradient(180deg, rgba(248, 251, 250, 0.98) 0%, var(--ysj-bg) 260px, var(--ysj-bg-deep) 100%);
  color: var(--ysj-text);
  font-family: "Microsoft YaHei", "PingFang SC", "Segoe UI", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
}

.main-shell {
  background:
    radial-gradient(circle at 44% -120px, rgba(6, 116, 103, 0.08), transparent 420px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0) 320px);
}

.content {
  padding-top: 24px;
}

.main-shell > .topbar {
  min-height: 70px;
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(200, 218, 212, 0.86);
  box-shadow: 0 8px 22px rgba(16, 39, 36, 0.04);
  backdrop-filter: blur(14px);
}

.main-shell > .topbar h1 {
  color: var(--ysj-text);
  font-size: 21px;
  font-weight: 950;
  line-height: 1.2;
}

.main-shell > .topbar p,
.small,
.muted,
.data-table-wrapper-meta {
  color: var(--ysj-muted);
}

.sidebar {
  background:
    linear-gradient(180deg, #06362f 0%, #07323a 50%, #062833 100%);
  box-shadow: inset -1px 0 rgba(255, 255, 255, 0.075), 10px 0 26px rgba(6, 42, 53, 0.1);
}

.brand-mark {
  border-radius: 10px;
  background: linear-gradient(135deg, #f7d96b 0%, #77d99d 100%);
  box-shadow: 0 9px 22px rgba(0, 0, 0, 0.2);
}

.side-nav a,
.sidebar details.side-subsection > summary {
  border-radius: 8px;
  transition: background 0.14s ease, border-color 0.14s ease, transform 0.14s ease;
}

.side-nav a:hover,
.sidebar details.side-subsection > summary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.1);
}

.side-nav a.primary-link {
  background: linear-gradient(135deg, #0b806f 0%, #0aa37f 100%);
  border-color: rgba(187, 247, 208, 0.28);
  box-shadow: 0 9px 20px rgba(0, 0, 0, 0.14);
}

.button,
a.button,
button[type="submit"],
.filter-bar button,
.pc-toolbar button,
.tc-filter-bar button,
.stc-filter-bar button,
.manual-upload-actions button {
  min-height: 38px;
  padding: 8px 15px;
  border-radius: var(--ysj-radius);
  border: 1px solid #056b60;
  background: linear-gradient(180deg, #0a7f72 0%, #056b60 100%);
  color: #ffffff;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0;
  box-shadow: 0 7px 16px rgba(6, 107, 96, 0.14);
  text-decoration: none;
}

.button:hover,
a.button:hover,
button[type="submit"]:hover,
.filter-bar button:hover,
.pc-toolbar button:hover,
.tc-filter-bar button:hover,
.stc-filter-bar button:hover,
.manual-upload-actions button:hover {
  border-color: #064e46;
  background: linear-gradient(180deg, #0b7d70 0%, #064e46 100%);
  filter: none;
}

.button.ghost,
a.button.ghost,
.button.secondary.ghost {
  border-color: #b9d2cc;
  background: #ffffff;
  color: var(--ysj-brand-strong);
  box-shadow: var(--ysj-shadow-flat);
}

.button.secondary,
button.secondary {
  border-color: #41545a;
  background: linear-gradient(180deg, #55676c 0%, #3c4d52 100%);
  color: #ffffff;
}

.button.disabled,
.button[disabled],
button[disabled] {
  border-color: #cbd8d5;
  background: #e6ecea;
  color: #7a8a85;
  box-shadow: none;
  cursor: default;
}

input,
select,
textarea {
  min-height: 38px;
  border: 1px solid var(--ysj-line-strong);
  border-radius: var(--ysj-radius);
  background: #ffffff;
  color: var(--ysj-text);
  font-size: 14px;
  box-shadow: inset 0 1px 0 rgba(15, 23, 42, 0.02);
}

input:focus,
select:focus,
textarea:focus,
button:focus-visible,
.button:focus-visible,
a:focus-visible {
  outline: 2px solid rgba(8, 125, 112, 0.22);
  outline-offset: 2px;
  border-color: #80bcb2;
}

.page-header,
.card,
.card-link,
.home-panel,
.home-module-card,
.home-source-card,
.home-status-card,
.table-panel,
.data-table-wrapper,
.store-history-panel,
.drawer-panel,
.manual-data-hero,
.manual-status-card,
.manual-action-card,
.manual-info-card,
.pc-command,
.pc-readiness,
.pc-summary,
.pc-toolbar,
.pc-main,
.pc-detail,
.pc-card,
.pc-panel,
.pc-dish-card,
.pc-sop-sheet,
.pc-sop-document-head,
.tc-command,
.tc-filter-bar,
.tc-panel,
.tc-detail-card,
.tc-summary-card,
.stc-command,
.stc-panel,
.stc-filter-bar,
.stc-summary-card,
.occ-card,
.occ-panel,
.oc-card,
.store-home-hero,
.store-home-field {
  border: 1px solid var(--ysj-line);
  border-radius: var(--ysj-radius);
  background: #ffffff;
  box-shadow: var(--ysj-shadow-sm);
}

.card-link:hover,
.home-module-card:hover,
.manual-action-card:hover,
.pc-card:hover,
.pc-dish-card:hover {
  border-color: #99cfc4;
  background: #fcfefd;
  box-shadow: 0 12px 26px rgba(8, 125, 112, 0.085);
  transform: translateY(-1px);
}

.page-header h2,
.manual-data-hero h2,
.pc-command h2,
.tc-command h2,
.stc-command h2,
h2 {
  color: var(--ysj-text);
  font-weight: 950;
  letter-spacing: 0;
}

.pc-command h2,
.manual-data-hero h2 {
  font-size: 26px;
}

.pc-eyebrow,
.tc-eyebrow,
.stc-eyebrow,
.manual-status-card span,
.card .label,
.card-link .label {
  color: var(--ysj-brand-strong);
  font-weight: 900;
}

.pc-lede,
.tc-lede,
.stc-lede,
.manual-data-hero p,
.manual-action-card small,
.manual-status-card small {
  color: var(--ysj-muted);
  line-height: 1.6;
}

.filter-bar,
.filter-bar.executive-filter,
.pc-toolbar,
.tc-filter-bar,
.stc-filter-bar {
  padding: 14px;
  border-color: var(--ysj-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 252, 251, 0.98) 100%);
  box-shadow: var(--ysj-shadow-sm);
}

.filter-control,
.pc-toolbar label,
.tc-filter-bar label,
.stc-filter-bar label {
  color: var(--ysj-muted);
  font-size: 12px;
  font-weight: 900;
}

.data-table-wrapper,
.table-panel,
.pc-table-wrap,
.tc-table-wrap,
.stc-table-wrap {
  overflow: hidden;
}

.data-table-wrapper-head,
.table-panel-head,
.pc-panel-head,
.tc-panel-head,
.stc-panel-head {
  border-bottom-color: var(--ysj-line);
  background: linear-gradient(180deg, #ffffff 0%, #f5faf8 100%);
}

table,
.data-table,
.executive-period-table,
.pc-table,
.tc-table,
.stc-table {
  border-color: var(--ysj-line);
}

th,
.data-table th,
.executive-period-table th,
.pc-table th,
.tc-table th,
.stc-table th {
  background: #edf6f3;
  color: #1d3430;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
}

td,
.data-table td,
.executive-period-table td,
.pc-table td,
.tc-table td,
.stc-table td {
  color: var(--ysj-text-soft);
  font-size: 13px;
}

tr:hover td {
  background: #f7fbfa;
}

.badge,
.status-pill,
.pc-badge,
.tc-badge,
.stc-badge,
.manual-status-badge,
.pc-health,
.tc-health,
.stc-health {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--ysj-line-strong);
  background: #f6faf9;
  color: var(--ysj-text-soft);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.status-pill.good,
.badge.good,
.pc-health[data-state="ok"],
.tc-health[data-state="ok"],
.stc-health[data-state="ok"],
.manual-status-badge.good {
  border-color: #a7e4d4;
  background: var(--ysj-brand-soft);
  color: var(--ysj-brand-strong);
}

.status-pill.warn,
.badge.warn,
.manual-status-badge.warn {
  border-color: #f4d58b;
  background: var(--ysj-gold-soft);
  color: var(--ysj-gold);
}

.status-pill.bad,
.badge.bad,
.pc-health[data-state="error"],
.tc-health[data-state="error"],
.stc-health[data-state="error"],
.manual-status-badge.bad {
  border-color: #fecaca;
  background: var(--ysj-red-soft);
  color: var(--ysj-red);
}

.level-tag,
.ed-grade {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-width: 62px;
  min-height: 26px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
  white-space: nowrap;
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.7), 0 4px 10px rgba(15, 23, 42, 0.045);
}

.level-tag.s,
.ed-grade-s {
  border-color: #b91c1c;
  background: linear-gradient(180deg, #ef4444 0%, #dc2626 100%);
  color: #ffffff !important;
}

.level-tag.a,
.ed-grade-a {
  border-color: #fde68a;
  background: linear-gradient(180deg, #fffdf2 0%, #fef3c7 100%);
  color: #92400e !important;
}

.level-tag.b,
.ed-grade-b {
  border-color: #0369a1;
  background: linear-gradient(180deg, #38bdf8 0%, #0284c7 100%);
  color: #ffffff !important;
}

.level-tag.c,
.level-tag.unrated,
.ed-grade-pending {
  border-color: #cbd5e1;
  background: #f8fafc;
  color: #64748b;
}

.notice,
.pc-alert,
.tc-alert,
.stc-alert {
  border-radius: var(--ysj-radius);
  border-color: var(--ysj-line);
  background: #ffffff;
  box-shadow: var(--ysj-shadow-sm);
}

.notice.good,
.tc-alert[data-kind="success"],
.stc-alert[data-kind="success"] {
  border-color: #a7e4d4;
  background: #effbf7;
  color: var(--ysj-brand-strong);
}

.notice.bad {
  border-color: #fecaca;
  background: #fff5f5;
  color: var(--ysj-red);
}

.ed-empty,
.pc-empty,
.tc-empty,
.stc-empty,
.empty {
  border: 1px dashed #bdd6cf;
  border-radius: var(--ysj-radius);
  background: linear-gradient(180deg, #fbfefd 0%, #f4faf8 100%);
  color: var(--ysj-muted);
  font-weight: 800;
}

.pagination,
.pc-pagination,
.tc-pagination,
.stc-pagination {
  gap: 8px;
}

.login-card {
  border-color: var(--ysj-line);
  border-radius: 12px;
  box-shadow: 0 18px 48px rgba(6, 42, 53, 0.12);
}

@media (max-width: 900px) {
  .content {
    padding: 16px;
  }

  .main-shell > .topbar {
    min-height: auto;
    padding: 16px;
  }

  .pc-command,
  .tc-command,
  .stc-command,
  .manual-data-hero {
    align-items: stretch;
    grid-template-columns: 1fr;
    flex-direction: column;
  }
}

/* Page-family visual standardization. These rules intentionally target the
   existing module prefixes so the system reads as one product, not a set of
   unrelated prototypes. */
.executive-dashboard,
.pc-shell,
.tc-shell,
.stc-shell,
.oc-shell,
.occ-shell,
.manual-data-center,
.import-center-simple {
  color: var(--ysj-text) !important;
  gap: 16px !important;
}

.ed-page-header,
.executive-data-page-head,
.pc-command,
.tc-command,
.stc-command,
.oc-hero,
.occ-hero,
.manual-data-hero {
  position: relative;
  min-height: 104px !important;
  padding: 20px 22px !important;
  border: 1px solid #cfdfda !important;
  border-left: 5px solid var(--ysj-brand) !important;
  border-radius: 8px !important;
  background:
    linear-gradient(135deg, rgba(232, 247, 242, 0.78) 0%, rgba(255, 255, 255, 0.98) 52%, rgba(255, 255, 255, 0.94) 100%) !important;
  box-shadow: 0 14px 34px rgba(17, 37, 33, 0.075) !important;
}

.ed-page-header h1,
.executive-data-page-title,
.pc-command h2,
.tc-command h2,
.stc-command h2,
.oc-title,
.manual-data-hero h2 {
  margin: 2px 0 6px !important;
  color: #0c201d !important;
  font-size: 27px !important;
  line-height: 1.16 !important;
  font-weight: 950 !important;
}

.ed-eyebrow,
.executive-data-page-note,
.pc-eyebrow,
.tc-eyebrow,
.stc-eyebrow,
.occ-eyebrow {
  color: var(--ysj-brand-strong) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
}

.ed-page-header p,
.executive-data-page-note,
.pc-lede,
.tc-lede,
.stc-lede,
.oc-subtitle,
.manual-data-hero p {
  max-width: 860px;
  color: var(--ysj-muted) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.ed-header-actions,
.pc-command-actions,
.tc-command-actions,
.stc-command-actions,
.manual-data-hero-actions {
  gap: 10px !important;
}

.ed-filter-pill,
.ed-icon-button,
.ed-link-button,
.ed-range-switch button,
.pc-segment,
.pc-tab-button,
.oc-tabs a,
.executive-data-tabs .button,
.tc-command-actions .button,
.stc-command-actions .button {
  min-height: 36px !important;
  border-radius: 8px !important;
  border: 1px solid #bfd7d0 !important;
  background: #ffffff !important;
  color: #07584f !important;
  box-shadow: 0 2px 0 rgba(16, 39, 36, 0.035) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.ed-range-switch button.active,
.pc-segment.is-active,
.pc-tab-button.is-active,
.oc-tabs a.active,
.executive-data-tabs .button:not(.ghost) {
  border-color: var(--ysj-brand) !important;
  background: linear-gradient(180deg, #0a7f72 0%, #056b60 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 8px 18px rgba(6, 107, 96, 0.14) !important;
}

.ed-kpi-grid,
.pc-card-grid,
.pc-card-grid.v15,
.tc-summary-grid,
.stc-summary-grid,
.manual-status-grid,
.oc-status-grid,
.oc-kpi-grid,
.occ-summary-grid,
.quality-summary-grid {
  gap: 12px !important;
}

.ed-kpi-card,
.ed-board-card,
.ed-ai-strip,
.ed-store-info-card,
.pc-card,
.pc-panel,
.pc-dish-card,
.pc-step-card,
.pc-ingredient-card,
.tc-summary-card,
.tc-panel,
.tc-detail-card,
.stc-summary-card,
.stc-panel,
.stc-detail-card,
.manual-status-card,
.manual-action-card,
.manual-info-card,
.quality-summary-card,
.oc-card,
.oc-kpi,
.occ-card-link,
.occ-item,
.occ-workflow-card,
.store-home-field,
.store-home-hero {
  border: 1px solid #d4e3de !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  box-shadow: 0 10px 26px rgba(17, 37, 33, 0.062) !important;
}

.ed-kpi-card,
.tc-summary-card,
.stc-summary-card,
.manual-status-card,
.quality-summary-card,
.oc-kpi {
  min-height: 108px !important;
  padding: 16px !important;
}

.ed-kpi-card strong,
.card .value,
.card-link .value,
.tc-summary-card strong,
.stc-summary-card strong,
.manual-status-card strong,
.quality-summary-card strong,
.oc-kpi strong,
.pc-card strong {
  color: #0d2521 !important;
  font-size: 26px !important;
  font-weight: 950 !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
}

.ed-kpi-card span:not(.ed-kpi-icon),
.tc-summary-card span,
.tc-summary-card small,
.stc-summary-card span,
.stc-summary-card small,
.manual-status-card span,
.manual-status-card small,
.quality-summary-card span,
.oc-kpi span,
.pc-card small {
  color: var(--ysj-muted) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
}

.ed-kpi-icon {
  width: 46px !important;
  height: 46px !important;
  border: 1px solid #add8cf !important;
  background: #edf8f5 !important;
  color: var(--ysj-brand-strong) !important;
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.8) !important;
}

.ed-board-head,
.pc-panel-head,
.tc-panel-head,
.stc-panel-head,
.oc-card-head,
.data-table-wrapper-head,
.table-panel-head {
  min-height: 58px !important;
  padding: 14px 16px !important;
  border-bottom: 1px solid #d8e6e2 !important;
  background: linear-gradient(180deg, #ffffff 0%, #f5faf8 100%) !important;
}

.ed-board-head h2,
.pc-panel-head h3,
.tc-panel-head h3,
.stc-panel-head h3,
.oc-card-head h2,
.data-table-wrapper-title,
.table-panel-title {
  margin: 0 !important;
  color: #10231f !important;
  font-size: 17px !important;
  line-height: 1.25 !important;
  font-weight: 950 !important;
}

.filter-bar,
.filter-bar.executive-filter,
.pc-toolbar,
.tc-filter-bar,
.stc-filter-bar,
.occ-filter-bar {
  gap: 12px !important;
  padding: 16px !important;
  border: 1px solid #d4e3de !important;
  border-radius: 8px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbfa 100%) !important;
  box-shadow: 0 8px 22px rgba(17, 37, 33, 0.052) !important;
}

.filter-control span,
.pc-filter-label,
.pc-toolbar-head span,
.tc-filter-bar label,
.stc-filter-bar label,
.occ-filter-bar label {
  color: #52675f !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

.filter-bar input,
.filter-bar select,
.pc-filter-field input,
.pc-filter-field select,
.tc-filter-bar input,
.tc-filter-bar select,
.stc-filter-bar input,
.stc-filter-bar select,
.occ-filter-bar select {
  height: 40px !important;
  border-color: #bdd6cf !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  color: #10231f !important;
  font-weight: 800 !important;
}

.data-table-wrapper,
.table-panel,
.pc-table-wrap,
.tc-table-wrap,
.stc-table-wrap,
.oc-table-wrap {
  border: 1px solid #d4e3de !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  box-shadow: 0 10px 26px rgba(17, 37, 33, 0.055) !important;
}

.data-table th,
.executive-period-table th,
.pc-table th,
.tc-table th,
.stc-table th,
.oc-table th {
  height: 42px !important;
  background: #edf6f3 !important;
  color: #203a35 !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  border-bottom: 1px solid #d4e3de !important;
}

.data-table td,
.executive-period-table td,
.pc-table td,
.tc-table td,
.stc-table td,
.oc-table td {
  height: 42px !important;
  color: #243b35 !important;
  font-size: 13px !important;
  border-bottom: 1px solid #e6efec !important;
}

.pc-health,
.tc-health,
.stc-health,
.status-pill,
.badge,
.pc-badge,
.tc-badge,
.stc-badge,
.occ-badge {
  min-height: 28px !important;
  border-radius: 999px !important;
  padding: 4px 11px !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

.pc-empty,
.tc-empty-state,
.stc-empty-state,
.oc-empty,
.ed-empty,
.pc-empty-rich {
  min-height: 116px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px dashed #b8d4cd !important;
  border-radius: 8px !important;
  background: #f8fbfa !important;
  color: #60736f !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

.pc-tabs,
.executive-data-tabs,
.oc-tabs,
.ed-legacy-nav {
  gap: 8px !important;
  padding: 10px !important;
  border: 1px solid #d4e3de !important;
  border-radius: 8px !important;
  background: #ffffff !important;
  box-shadow: 0 6px 18px rgba(17, 37, 33, 0.045) !important;
}

.oc-hero .oc-status-grid,
.occ-hero .oc-status-grid,
.oc-hero .oc-kpi-grid,
.occ-hero .oc-kpi-grid {
  min-width: 0 !important;
}

.oc-hero .oc-kpi,
.occ-hero .oc-kpi {
  min-width: 0 !important;
  overflow: hidden !important;
}

.oc-hero .oc-kpi strong,
.occ-hero .oc-kpi strong {
  display: -webkit-box !important;
  overflow: hidden !important;
  color: #10231f !important;
  font-size: clamp(18px, 1.55vw, 23px) !important;
  line-height: 1.12 !important;
  overflow-wrap: anywhere !important;
  text-overflow: ellipsis !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
}

.manual-data-center > section:first-child,
.import-center-simple > section:first-child,
.quality-issue-details > section:first-child {
  border-left: 5px solid var(--ysj-brand) !important;
}
