Files
ewoooc/web/static/css/ewoooc-v3-page-guard.css

1099 lines
29 KiB
CSS

/*
* EwoooC V3 Page Guard
* Loaded after page-level CSS to keep migrated Flask/Jinja pages aligned with
* the production design spec while old page files are cleaned incrementally.
*/
.momo-app:not(.momo-observability-mode) {
--momo-page-title-size: 1.8rem;
--momo-page-section-title-size: 1.4rem;
--momo-page-card-title-size: 1rem;
--momo-page-kpi-size: 1.85rem;
--momo-page-readable-line: 74ch;
--momo-page-action-strip-width: 1040px;
}
.momo-app:not(.momo-observability-mode) .momo-content {
overflow-x: clip;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
*,
*::before,
*::after
) {
min-width: 0;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
.page-header,
.card-header,
.momo-card-head,
[class$="-head"],
[class$="-header"],
[class$="-toolbar"],
[class$="-actions"],
[class$="-filters"],
[class$="-controls"]
) {
gap: var(--momo-space-3, 12px);
min-width: 0;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
.card,
.momo-card,
.alert,
[class$="-card"],
[class$="-panel"],
[class$="-hero"],
[class$="-notice"],
[class$="-banner"]
) {
max-width: 100%;
overflow-wrap: anywhere;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
.alert,
[class$="-notice"],
[class$="-banner"],
[class$="-hint"]
) {
max-width: min(100%, var(--momo-page-action-strip-width));
line-height: 1.5;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
.btn,
button,
[role="button"]
):not(.momo-icon-button):not(.momo-mobile-menu-button):not(.btn-close) {
max-width: 100%;
min-height: 36px;
align-items: center;
justify-content: center;
line-height: 1.2;
overflow-wrap: anywhere;
text-align: center;
white-space: normal;
}
.momo-app:not(.momo-observability-mode) .momo-content .btn:not(.btn-close) {
display: inline-flex;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
.btn-primary,
.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-warning,
.btn-outline-danger,
.btn-outline-success
) {
border-width: 1px;
font-weight: 800;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
p,
.lead,
.text-muted,
[class$="-subtitle"],
[class$="-copy"],
[class$="-note"],
[class$="-description"]
) {
max-width: var(--momo-page-readable-line);
overflow-wrap: anywhere;
}
.momo-app:not(.momo-observability-mode) .momo-content :is(
.page-header,
[class$="-hero"],
[class$="-head"],
[class$="-header"]
) :is(
p,
.lead,
[class$="-subtitle"],
[class$="-description"],
[class$="-note"]
) {
display: -webkit-box;
overflow: hidden;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}
.momo-app:not(.momo-observability-mode) :is(
.home-hero__title,
.ai-recommend-title,
.ar-hero__title h1,
.monthly-analysis-title,
.ms-page-head__title,
.edm-head__title,
.edm-page .page-head h2,
.edm-page .campaign-title,
.sa-page-head__title,
.daily-hero__title,
.ga-page-head__h1,
.vendor-title,
.page-logs .page-header h4
) {
color: var(--momo-text-primary) !important;
font-family: var(--momo-font-display) !important;
font-size: var(--momo-page-title-size) !important;
font-weight: 800 !important;
line-height: 1.2 !important;
letter-spacing: 0 !important;
text-wrap: pretty;
}
.momo-app:not(.momo-observability-mode) :is(
.fn-card__title,
.edm-slotpanel__title,
.ms-chart-card__title,
.ms-special__title,
.ms-data-table__title,
.dashboard-section-label .title,
.dashboard-table-title,
.dashboard-focus-title,
.sa-filter-head__title,
.sa-filter-group__title,
.sa-empty__title,
.sa-panel__title,
.ga-empty-state h2,
.ga-chart-card__title,
.ai-card__title,
.ai-notice__title,
.home-manual__title,
.home-manual__subhead,
.crawler-title,
.page-logs .control-section-title,
.card-title
) {
color: var(--momo-text-primary) !important;
font-family: var(--momo-font-display) !important;
font-size: var(--momo-page-card-title-size) !important;
font-weight: 700 !important;
line-height: 1.4 !important;
letter-spacing: 0 !important;
}
.momo-app:not(.momo-observability-mode) :is(
.stat-card h2,
.stat-number,
.dashboard-kpi-value,
.dashboard-focus-number,
.dashboard-ai-summary-value,
.kpi-item-value,
.kpi-value,
.kpi-card__value,
.sa-yoy-card__value,
.sa-insights__value,
.ga-kpi__value,
.monthly-analysis-page .kpi-value,
.vendor-pulse-value,
.vendor-metric-value,
.page-logs .stat-value,
.daily-mobile-day__value
) {
font-family: var(--momo-font-mono) !important;
font-size: var(--momo-page-kpi-size) !important;
font-weight: 800 !important;
line-height: 1.1 !important;
letter-spacing: 0 !important;
font-variant-numeric: tabular-nums;
}
.momo-app:not(.momo-observability-mode) :is(
.home-hero,
.fn-card,
.dashboard-kpi-grid,
.dashboard-focus-card,
.dashboard-filter-card,
.dashboard-table-card,
.ai-recommend-hero,
.ar-hero,
.monthly-analysis-hero,
.ms-page-head,
.edm-head,
.edm-promonav,
.edm-statusbar,
.edm-slotpanel,
.edm-page .table-container,
.edm-page .campaign-hero,
.edm-page .campaign-kpi-panel,
.edm-page .campaign-hero-content,
.sa-page-head,
.sa-filter-card,
.sa-panel,
.sa-kpi,
.daily-hero,
.daily-kpi-grid,
.kpi-card,
.daily-calendar,
.ga-page-head,
.ga-kpi,
.ga-chart-card,
.vendor-hero-panel,
.vendor-card,
.vendor-table-card,
.vendor-pulse,
.crawler-card,
.home-manual,
.page-logs .page-header,
.page-logs .stat-card,
.page-logs .control-panel,
.page-logs .log-container-wrapper,
.momo-app .card
) {
border-radius: 8px !important;
}
.momo-app:not(.momo-observability-mode) :is(
.home-hero,
.ai-recommend-hero,
.ar-hero,
.monthly-analysis-hero,
.ms-page-head,
.edm-head,
.edm-page .campaign-hero,
.edm-page .campaign-hero-content,
.sa-page-head,
.daily-hero,
.ga-page-head,
.vendor-hero-panel
) {
background-color: var(--momo-bg-surface) !important;
background-image: none !important;
border: 1px solid var(--momo-border-strong) !important;
box-shadow: var(--momo-shadow-soft) !important;
}
.momo-app:not(.momo-observability-mode) :is(
.monthly-analysis-page .filter-section,
.sa-filter-card,
.ms-filter-card,
.filter-section
) {
background-color: var(--momo-bg-paper) !important;
background-image: none !important;
color: var(--momo-text-primary) !important;
}
.momo-app:not(.momo-observability-mode) :is(
.monthly-analysis-page .form-label,
.filter-section .form-label,
.sa-filter-group__title,
.kpi-item-label,
.kpi-card__label,
.ga-kpi__label,
.stat-label,
.vendor-eyebrow
) {
color: var(--momo-text-secondary) !important;
font-family: var(--momo-font-display) !important;
font-size: 0.78rem !important;
font-weight: 700 !important;
letter-spacing: 0.06em !important;
text-transform: uppercase;
}
.momo-app:not(.momo-observability-mode) :is(
.btn,
.form-control,
.form-select,
.input-group-text,
.dashboard-search,
.dashboard-select,
.dashboard-segmented,
.dashboard-action-link,
.dashboard-action-button
) {
border-radius: 8px !important;
font-family: var(--momo-font-family) !important;
letter-spacing: 0 !important;
}
.momo-app:not(.momo-observability-mode) .page-logs :is(
.btn-control,
.btn-filter,
.btn-font-size,
.search-box input
) {
border-radius: 8px !important;
font-family: var(--momo-font-family) !important;
letter-spacing: 0 !important;
}
.momo-app:not(.momo-observability-mode) :is(.btn-primary, .vendor-action.is-primary, .fn-card__cta) {
background-color: var(--momo-page-accent) !important;
background-image: none !important;
border-color: var(--momo-page-accent-dark) !important;
color: var(--momo-page-inverse) !important;
}
.momo-app:not(.momo-observability-mode) :is(.table thead th, table thead th) {
background-color: var(--momo-bg-paper) !important;
color: var(--momo-text-secondary) !important;
font-family: var(--momo-font-mono) !important;
font-size: 0.82rem !important;
font-weight: 700 !important;
letter-spacing: 0.05em !important;
}
.momo-app:not(.momo-observability-mode) :is(.table-responsive, .table-container) {
max-width: 100%;
overflow-x: auto;
}
.momo-app:not(.momo-observability-mode) :is(.home-hero__decor, .stat-icon, .kpi-card__icon-bg) {
opacity: 0.22;
}
.momo-app:not(.momo-observability-mode) .daily-sales-page .kpi-card__body {
padding: 0.82rem 0.9rem !important;
}
.momo-app:not(.momo-observability-mode) .daily-sales-page .kpi-card__value {
font-size: clamp(1.35rem, 1.7vw, 1.55rem) !important;
white-space: nowrap;
}
.momo-app:not(.momo-observability-mode) .dashboard-table,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table {
width: 100% !important;
min-width: 0 !important;
table-layout: fixed;
}
.momo-app:not(.momo-observability-mode) .dashboard-table th,
.momo-app:not(.momo-observability-mode) .dashboard-table td,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table th,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td {
min-width: 0;
overflow-wrap: anywhere;
white-space: normal;
}
.momo-app:not(.momo-observability-mode) .dashboard-table-wrap,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table-wrap {
overflow-x: visible !important;
}
.momo-app:not(.momo-observability-mode) .dashboard-table th:nth-child(1),
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(1) {
width: 7rem;
}
.momo-app:not(.momo-observability-mode) .dashboard-table th:nth-child(2),
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(2) {
width: 24%;
}
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table th:nth-child(1),
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(1) {
width: 7rem;
}
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table th:nth-child(2),
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(2) {
width: 36%;
}
.momo-app:not(.momo-observability-mode) .dashboard-table-wrap.is-review-wrap {
overflow-x: auto !important;
-webkit-overflow-scrolling: touch;
}
.momo-app:not(.momo-observability-mode) .dashboard-table-wrap.is-ai-picks-wrap {
overflow-x: auto !important;
-webkit-overflow-scrolling: touch;
}
.momo-app:not(.momo-observability-mode) .dashboard-table.is-ai-picks {
width: max(100%, 1660px) !important;
min-width: 1660px !important;
table-layout: fixed;
}
.momo-app:not(.momo-observability-mode) .dashboard-table.is-review {
width: max(100%, 1540px) !important;
min-width: 1540px !important;
table-layout: fixed;
}
@media (max-width: 768px) {
.momo-app:not(.momo-observability-mode) {
--momo-page-title-size: 1.55rem;
--momo-page-section-title-size: 1.18rem;
--momo-page-card-title-size: 0.98rem;
--momo-page-kpi-size: 1.35rem;
}
.momo-app:not(.momo-observability-mode) :is(
.home-hero,
.ai-recommend-hero,
.ar-hero,
.monthly-analysis-hero,
.ms-page-head,
.edm-head,
.edm-page .campaign-hero,
.sa-page-head,
.daily-hero,
.ga-page-head,
.vendor-hero-panel
) {
padding: 0.9rem !important;
}
.momo-app:not(.momo-observability-mode) :is(
.monthly-analysis-hero,
.ms-page-head,
.vendor-hero,
.edm-page .campaign-hero-grid,
.edm-page .campaign-hero,
.sa-page-head,
.ga-page-head
) {
grid-template-columns: 1fr !important;
}
.momo-app:not(.momo-observability-mode) :is(
.home-hero__title,
.ai-recommend-title,
.ar-hero__title h1,
.monthly-analysis-title,
.ms-page-head__title,
.edm-head__title,
.sa-page-head__title,
.daily-hero__title,
.ga-page-head__h1,
.vendor-title,
.page-logs .page-header h4
) {
align-items: flex-start;
overflow-wrap: anywhere;
}
.momo-app:not(.momo-observability-mode) .daily-sales-page .kpi-card__value {
font-size: 1.32rem !important;
}
.momo-app:not(.momo-observability-mode) .edm-page :is(
.campaign-switcher,
.campaign-slot-tabs,
.campaign-filterbar
) {
display: grid !important;
grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
gap: 8px !important;
overflow: visible !important;
}
.momo-app:not(.momo-observability-mode) .edm-page :is(
.campaign-tab,
.campaign-slot-tab,
.campaign-filter-chip
) {
width: 100% !important;
min-width: 0 !important;
justify-content: center !important;
text-align: center !important;
white-space: nowrap;
}
.momo-app:not(.momo-observability-mode) .dashboard-table-wrap::before,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table-wrap::before {
display: none !important;
}
.momo-app:not(.momo-observability-mode) .dashboard-table,
.momo-app:not(.momo-observability-mode) .dashboard-table tbody,
.momo-app:not(.momo-observability-mode) .dashboard-table tr,
.momo-app:not(.momo-observability-mode) .dashboard-table td,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table tbody,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table tr,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td {
display: block;
width: 100% !important;
}
.momo-app:not(.momo-observability-mode) .dashboard-table thead,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table thead {
display: none !important;
}
.momo-app:not(.momo-observability-mode) .dashboard-table tr,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table tr {
margin: 0;
padding: 0.85rem;
background: var(--momo-bg-surface);
border-top: 1px solid var(--momo-border-light);
}
.momo-app:not(.momo-observability-mode) .dashboard-table tr:first-child,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table tr:first-child {
border-top: 0;
}
.momo-app:not(.momo-observability-mode) .dashboard-table td,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td {
display: grid;
grid-template-columns: 6.8rem minmax(0, 1fr);
gap: 0.75rem;
align-items: start;
padding: 0.45rem 0 !important;
border: 0 !important;
text-align: left !important;
}
.momo-app:not(.momo-observability-mode) .dashboard-table td::before,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td::before {
color: var(--momo-text-tertiary);
font-family: var(--momo-font-mono);
font-size: 0.68rem;
font-weight: 800;
letter-spacing: 0.06em;
text-transform: uppercase;
}
.momo-app:not(.momo-observability-mode) .dashboard-table td[colspan],
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td[colspan] {
grid-template-columns: 1fr;
}
.momo-app:not(.momo-observability-mode) .dashboard-table td[colspan]::before,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td[colspan]::before {
content: none;
display: none;
}
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(1)::before { content: "分類"; }
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(2)::before { content: "商品"; }
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(3)::before { content: "MOMO"; }
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(4)::before { content: "PChome"; }
.momo-app:not(.momo-observability-mode) .dashboard-table td:nth-child(5)::before { content: "競價"; }
.momo-app:not(.momo-observability-mode) .dashboard-table:not(.is-ai-picks):not(.is-review) td:nth-child(6)::before { content: "昨日"; }
.momo-app:not(.momo-observability-mode) .dashboard-table:not(.is-ai-picks):not(.is-review) td:nth-child(7)::before { content: "週"; }
.momo-app:not(.momo-observability-mode) .dashboard-table:not(.is-ai-picks):not(.is-review) td:nth-child(8)::before { content: "更新"; }
.momo-app:not(.momo-observability-mode) .dashboard-table:not(.is-ai-picks):not(.is-review) td:nth-child(9)::before { content: "上架"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-ai-picks td:nth-child(6)::before { content: "AI"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-ai-picks td:nth-child(7)::before { content: "昨日"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-ai-picks td:nth-child(8)::before { content: "週"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-ai-picks td:nth-child(9)::before { content: "更新"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-ai-picks td:nth-child(10)::before { content: "上架"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-review td:nth-child(2)::before { content: "商品/MOMO"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-review td:nth-child(3)::before { content: "PChome候選"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-review td:nth-child(4)::before { content: "覆核判讀"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-review td:nth-child(5)::before { content: "下一步"; }
.momo-app:not(.momo-observability-mode) .dashboard-table.is-review td:nth-child(6)::before { content: "紀錄"; }
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(1)::before { content: "分類"; }
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(2)::before { content: "商品"; }
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(3)::before { content: "價格"; }
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(4)::before { content: "銷售"; }
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table td:nth-child(5)::before { content: "追蹤"; }
.momo-app:not(.momo-observability-mode) .dashboard-table .dashboard-product-cell,
.momo-app:not(.momo-observability-mode) .edm-page .campaign-table .campaign-product-cell {
align-items: flex-start;
}
}
/* AI observability pages load page-level CSS before this guard. Keep the 10
cockpit pages on the same V3 tokens even when older inline styles remain. */
body.momo-observability-mode {
--obs-title-size: var(--momo-text-display, 30px);
--obs-value-size: var(--momo-text-display, 30px);
--obs-section-title-size: var(--momo-text-title, 17px);
--obs-body-size: var(--momo-text-body, 14px);
--obs-label-size: var(--momo-text-label, 11px);
--obs-ink: var(--momo-text-primary, #2a2520);
--obs-muted: var(--momo-text-secondary, #6b6155);
--obs-accent: var(--momo-page-accent, var(--momo-warm-saffron, #b8792f));
--obs-line: var(--momo-border, rgba(42, 37, 32, 0.16));
--obs-card: var(--momo-bg-surface, #faf6ec);
--obs-dot: radial-gradient(color-mix(in srgb, var(--momo-text-tertiary, #9b9081) 28%, transparent) 0.8px, transparent 0.8px);
}
body.momo-observability-mode .momo-content {
background-color: var(--momo-bg-body) !important;
background-image: var(--obs-dot) !important;
background-size: 16px 16px !important;
color: var(--obs-ink) !important;
font-family: var(--momo-font-family) !important;
overflow-x: hidden;
}
body.momo-observability-mode :is(
.obs-war-room,
.obs-warroom,
.agent-page,
.biz-warroom,
.runtime-page,
.calls-page,
.gov-page,
.gate-page,
.rag-page,
.quality-page,
.ppt-page
) {
color: var(--obs-ink) !important;
font-family: var(--momo-font-family) !important;
}
body.momo-observability-mode :is(
.obs-hero,
.agent-hero,
.biz-command,
.runtime-hero,
.calls-hero,
.gov-hero,
.gate-hero,
.rag-hero,
.qa-hero,
.quality-hero,
.ppt-hero,
.container-fluid > h2:first-child
) {
border: 1px solid var(--obs-line) !important;
border-radius: var(--momo-radius-md, 8px) !important;
background-color: var(--momo-bg-surface) !important;
background-image: var(--obs-dot) !important;
background-size: 16px 16px !important;
box-shadow: var(--momo-shadow-soft) !important;
color: var(--obs-ink) !important;
padding: var(--momo-space-4, 16px) !important;
}
body.momo-observability-mode .biz-warroom::before,
body.momo-observability-mode .biz-command::before,
body.momo-observability-mode .biz-command::after {
display: none !important;
}
body.momo-observability-mode :is(
h1,
h2,
h3,
h4,
h5,
h6,
.obs-title,
.agent-title,
.biz-command h1,
.runtime-title,
.calls-title,
.gov-title,
.gate-title,
.rag-title,
.qa-title,
.quality-title,
.ppt-title
) {
color: var(--obs-ink) !important;
font-family: var(--momo-font-display) !important;
font-weight: 800 !important;
letter-spacing: 0 !important;
line-height: 1.2 !important;
}
body.momo-observability-mode :is(
.obs-title,
.agent-title,
.biz-command h1,
.runtime-title,
.calls-title,
.gov-title,
.gate-title,
.rag-title,
.qa-title,
.quality-title,
.ppt-title,
.container-fluid > h2:first-child
) {
font-size: var(--obs-title-size) !important;
max-width: 820px;
}
body.momo-observability-mode :is(
.obs-subtitle,
.agent-subtitle,
.biz-command p,
.runtime-subtitle,
.calls-subtitle,
.gov-subtitle,
.gate-subtitle,
.rag-subtitle,
.qa-subtitle,
.quality-subtitle,
.ppt-subtitle,
.text-muted
) {
color: var(--obs-muted) !important;
font-family: var(--momo-font-family) !important;
font-size: var(--obs-body-size) !important;
letter-spacing: 0 !important;
line-height: 1.7 !important;
}
body.momo-observability-mode :is(
.obs-kicker,
.agent-kicker,
.biz-kicker,
.runtime-kicker,
.calls-kicker,
.gov-kicker,
.gate-kicker,
.rag-kicker,
.qa-kicker,
.quality-kicker,
.ppt-kicker,
.obs-label,
.agent-label,
.biz-signal .label,
.runtime-label,
.calls-label,
.gov-label,
.gate-label,
.rag-label,
.qa-label,
.quality-label,
.ppt-label,
[class$="-label"]
) {
color: var(--obs-accent) !important;
font-family: var(--momo-font-mono) !important;
font-size: var(--obs-label-size) !important;
font-weight: 700 !important;
letter-spacing: 0 !important;
text-transform: none !important;
}
body.momo-observability-mode :is(
.obs-value,
.obs-signal-value,
.agent-value,
.biz-value,
.biz-signal .value,
.runtime-value,
.calls-value,
.gov-value,
.gate-value,
.rag-value,
.qa-value,
.quality-value,
.ppt-value,
.display-4,
.display-5,
.h1,
[class$="-mini"] strong
) {
color: var(--obs-ink) !important;
font-family: var(--momo-font-mono) !important;
font-size: var(--obs-value-size) !important;
font-weight: 800 !important;
font-variant-numeric: tabular-nums;
letter-spacing: 0 !important;
line-height: 1.1 !important;
}
body.momo-observability-mode :is(
.obs-panel-title,
.agent-panel-title,
.biz-panel-head h3,
.runtime-panel-title,
.calls-panel-title,
.gov-panel-title,
.gate-panel-title,
.rag-panel-title,
.qa-panel-title,
.quality-panel-title,
.ppt-panel-title,
[class$="-table-title"] h3,
.card-title
) {
font-size: var(--obs-section-title-size) !important;
letter-spacing: 0 !important;
line-height: 1.35 !important;
}
body.momo-observability-mode :is(
.card,
.obs-signal,
.agent-signal,
.biz-signal,
.runtime-signal,
.calls-signal,
.gov-signal,
.gate-signal,
.rag-signal,
.qa-signal,
.quality-signal,
.ppt-signal,
.obs-panel,
.agent-panel,
.biz-panel,
.runtime-panel,
.calls-panel,
.gov-panel,
.gate-panel,
.rag-panel,
.qa-panel,
.quality-panel,
.ppt-panel,
.agent-card,
.caller-card,
.rec-card,
.fix-card,
.root-card,
.episode-card,
.biz-decision-card,
.obs-route-card,
[class$="-mini"],
.strategy-card,
.episode-text,
.similar-box,
.host-lane,
.list-group-item,
.dropdown-menu,
.modal-content,
.alert
) {
border-color: var(--obs-line) !important;
border-radius: var(--momo-radius-md, 8px) !important;
background-color: var(--obs-card) !important;
background-image: var(--obs-dot) !important;
background-size: 14px 14px !important;
box-shadow: var(--momo-shadow-soft) !important;
color: var(--obs-ink) !important;
}
body.momo-observability-mode :is(
.obs-table-shell,
.agent-table-shell,
.biz-table-shell,
.runtime-table-shell,
.calls-table-shell,
.gov-table-shell,
.gate-table-shell,
.rag-table-shell,
.qa-table-shell,
.quality-table-shell,
.ppt-table-shell,
.table-responsive,
.obs-chart-frame,
.chart-frame,
.chart-container,
.obs-modal-preview
) {
max-width: 100%;
overflow-x: auto;
border-color: var(--obs-line) !important;
border-radius: var(--momo-radius-md, 8px) !important;
background-color: var(--momo-bg-surface) !important;
background-image: var(--obs-dot) !important;
background-size: 14px 14px !important;
box-shadow: var(--momo-shadow-soft) !important;
}
body.momo-observability-mode :is(.btn, .form-control, .form-select, .input-group-text, .badge) {
border-radius: var(--momo-radius-md, 8px) !important;
font-family: var(--momo-font-family) !important;
letter-spacing: 0 !important;
}
body.momo-observability-mode .badge {
border: 1px solid var(--momo-border-light) !important;
background: var(--momo-tag-muted-bg) !important;
color: var(--momo-tag-muted-text) !important;
font-family: var(--momo-font-mono) !important;
font-size: var(--momo-text-label) !important;
font-weight: 700 !important;
}
body.momo-observability-mode :is(.badge.bg-success, .status-good) {
color: var(--momo-success-text) !important;
}
body.momo-observability-mode .badge.bg-success {
background: var(--momo-success-bg) !important;
border-color: var(--momo-success-border) !important;
}
body.momo-observability-mode :is(.badge.bg-warning, .status-warn) {
color: var(--momo-warning-text) !important;
}
body.momo-observability-mode .badge.bg-warning {
background: var(--momo-warning-bg) !important;
border-color: var(--momo-warning-border) !important;
}
body.momo-observability-mode :is(.badge.bg-danger, .status-bad) {
color: var(--momo-danger-text) !important;
}
body.momo-observability-mode .badge.bg-danger {
background: var(--momo-danger-bg) !important;
border-color: var(--momo-danger-border) !important;
}
body.momo-observability-mode :is(.badge.bg-info, .badge.bg-primary, .badge.bg-secondary, .badge.bg-light, .status-blue) {
color: var(--momo-info-text) !important;
}
body.momo-observability-mode :is(.badge.bg-info, .badge.bg-primary, .badge.bg-secondary, .badge.bg-light) {
background: var(--momo-info-bg) !important;
border-color: var(--momo-info-border) !important;
}
body.momo-observability-mode .table {
--bs-table-bg: transparent;
--bs-table-color: var(--obs-ink);
color: var(--obs-ink) !important;
font-size: var(--momo-text-body-sm) !important;
}
body.momo-observability-mode :is(.table thead th, table thead th, .table-light th) {
background: var(--momo-bg-paper) !important;
color: var(--momo-text-secondary) !important;
font-family: var(--momo-font-mono) !important;
font-size: var(--momo-text-label) !important;
font-weight: 700 !important;
letter-spacing: 0 !important;
white-space: nowrap;
}
body.momo-observability-mode :is(
.obs-command-strip,
.agent-command,
.biz-signal-grid,
.runtime-command,
.calls-command,
.gov-command,
.gate-command,
.rag-command,
.qa-command,
.quality-command,
.ppt-command
) {
display: grid !important;
grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)) !important;
gap: var(--momo-space-3, 12px) !important;
}
body.momo-observability-mode :is(
.obs-grid,
.agent-grid,
.biz-hero,
.biz-layout,
.runtime-grid,
.calls-grid,
.gov-grid,
.gate-grid,
.rag-grid,
.qa-grid,
.quality-grid,
.ppt-grid
) {
display: grid !important;
grid-template-columns: minmax(0, 1fr) minmax(min(100%, 320px), 0.42fr) !important;
gap: var(--momo-space-4, 16px) !important;
max-width: 100%;
}
@media (max-width: 900px) {
body.momo-observability-mode {
--obs-title-size: 24px;
--obs-value-size: 24px;
}
body.momo-observability-mode :is(
.obs-grid,
.agent-grid,
.biz-hero,
.biz-layout,
.runtime-grid,
.calls-grid,
.gov-grid,
.gate-grid,
.rag-grid,
.qa-grid,
.quality-grid,
.ppt-grid
) {
grid-template-columns: 1fr !important;
}
}
@media (max-width: 560px) {
body.momo-observability-mode {
--obs-title-size: 20px;
--obs-value-size: 20px;
}
body.momo-observability-mode :is(.obs-hero, .agent-hero, .biz-command, .runtime-hero, .calls-hero, .gov-hero, .gate-hero, .rag-hero, .qa-hero, .quality-hero, .ppt-hero) {
padding: 0.72rem !important;
}
body.momo-observability-mode :is(
.obs-command-strip,
.agent-command,
.biz-signal-grid,
.runtime-command,
.calls-command,
.gov-command,
.gate-command,
.rag-command,
.qa-command,
.quality-command,
.ppt-command
) {
gap: 8px !important;
grid-template-columns: repeat(auto-fit, minmax(126px, 1fr)) !important;
}
body.momo-observability-mode :is(
.obs-signal,
.agent-signal,
.biz-signal,
.runtime-signal,
.calls-signal,
.gov-signal,
.gate-signal,
.rag-signal,
.qa-signal,
.quality-signal,
.ppt-signal
) {
min-height: auto !important;
padding: 0.62rem !important;
}
body.momo-observability-mode :is(
.obs-subtitle,
.agent-subtitle,
.biz-command p,
.runtime-subtitle,
.calls-subtitle,
.gov-subtitle,
.gate-subtitle,
.rag-subtitle,
.qa-subtitle,
.quality-subtitle,
.ppt-subtitle
) {
line-height: 1.55 !important;
}
body.momo-observability-mode :is(.table-responsive, .obs-table-shell, [class$="-table-shell"]) {
margin-left: 0 !important;
margin-right: 0 !important;
}
}