Files
ewoooc/web/static/css/page-vendor-tools.css
OoO 9dfb7d1514
All checks were successful
CD Pipeline / deploy (push) Successful in 58s
統一登入與廠商工具頁新版設計
2026-05-14 20:43:21 +08:00

371 lines
9.7 KiB
CSS

.vendor-tools-page {
display: grid;
gap: var(--momo-space-5);
color: var(--momo-text-primary);
}
.vendor-tools-page .container,
.vendor-tools-page .container-fluid {
max-width: 100%;
padding: 0 !important;
}
.vendor-tools-kicker {
display: inline-flex;
align-items: center;
gap: 8px;
margin-bottom: var(--momo-space-2);
color: var(--momo-page-accent-dark);
font-family: var(--momo-font-mono);
font-size: var(--momo-text-label);
font-weight: 700;
letter-spacing: 0.04em;
}
.vendor-tools-header {
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
gap: var(--momo-space-4);
align-items: end;
padding: var(--momo-space-5);
border: 1px solid var(--momo-border-light);
border-radius: var(--momo-radius-lg);
background:
radial-gradient(circle at 14px 14px, rgba(172, 92, 58, 0.16) 1.2px, transparent 1.4px) 0 0 / 18px 18px,
var(--momo-bg-surface);
}
.vendor-tools-header h1 {
margin: 0;
font-family: var(--momo-font-display);
font-size: clamp(1.55rem, 2.2vw, 2.2rem);
font-weight: 800;
letter-spacing: 0;
color: var(--momo-text-primary);
}
.vendor-tools-header p {
max-width: 760px;
margin: var(--momo-space-2) 0 0;
color: var(--momo-text-secondary);
line-height: 1.65;
}
.vendor-tools-nav {
display: flex;
flex-wrap: wrap;
justify-content: flex-end;
gap: 8px;
}
.vendor-tools-nav a {
display: inline-flex;
align-items: center;
gap: 7px;
min-height: 36px;
padding: 7px 11px;
border: 1px solid var(--momo-border-light);
border-radius: var(--momo-radius-sm);
background: var(--momo-bg-elevated);
color: var(--momo-text-secondary);
font-family: var(--momo-font-display);
font-size: var(--momo-text-body-sm);
font-weight: 650;
text-decoration: none;
}
.vendor-tools-nav a:hover,
.vendor-tools-nav a.is-active {
border-color: var(--momo-page-accent-line);
background: var(--momo-page-accent-soft);
color: var(--momo-page-accent-dark);
}
.vendor-tools-body {
display: grid;
gap: var(--momo-space-4);
}
.vendor-tools-page h2,
.vendor-tools-page h3,
.vendor-tools-page h4,
.vendor-tools-page h5,
.vendor-tools-page h6 {
color: var(--momo-text-primary);
font-family: var(--momo-font-display);
letter-spacing: 0;
}
.vendor-tools-page h2 {
font-size: 1.28rem;
font-weight: 800;
}
.vendor-tools-page .section-tabs,
.vendor-tools-page .table-container,
.vendor-tools-page .stats-card,
.vendor-tools-page .card {
border: 1px solid var(--momo-border-light) !important;
border-radius: var(--momo-radius-md) !important;
background: var(--momo-bg-surface) !important;
box-shadow: none !important;
}
.vendor-tools-page .section-tabs {
overflow: hidden;
margin-bottom: var(--momo-space-4);
}
.vendor-tools-page .section-tabs .nav-link {
border: 0;
border-radius: 0;
padding: 0.82rem 1rem;
color: var(--momo-text-secondary);
font-family: var(--momo-font-display);
font-weight: 700;
}
.vendor-tools-page .section-tabs .nav-link.active {
background: var(--momo-text-primary) !important;
color: var(--momo-bg-paper) !important;
}
.vendor-tools-page .section-tabs .nav-link:hover:not(.active) {
background: var(--momo-bg-paper);
color: var(--momo-text-primary);
}
.vendor-tools-page .stats-card {
padding: var(--momo-space-4);
min-height: 118px;
}
.vendor-tools-page .stats-number,
.vendor-tools-page h3[id^="stat"] {
color: var(--momo-text-primary) !important;
font-family: var(--momo-font-mono);
font-size: clamp(1.45rem, 2vw, 1.95rem) !important;
font-weight: 800 !important;
letter-spacing: 0;
}
.vendor-tools-page .table-container {
overflow: hidden;
}
.vendor-tools-page .table-container .table-responsive {
max-width: 100%;
overflow-x: auto;
}
.vendor-tools-page .table {
min-width: 860px;
}
.vendor-tools-page .table tbody tr:hover {
transform: none !important;
}
.vendor-tools-page .email-badge,
.vendor-tools-page .status-badge {
display: inline-flex;
align-items: center;
min-height: 24px;
margin: 2px;
padding: 3px 8px;
border: 1px solid var(--momo-border-light);
border-radius: var(--momo-radius-sm);
background: var(--momo-bg-paper);
color: var(--momo-text-secondary);
font-family: var(--momo-font-mono);
font-size: 0.78rem;
font-weight: 700;
}
.vendor-tools-page .status-sent {
border-color: var(--momo-success-border);
background: var(--momo-success-bg);
color: var(--momo-success-text);
}
.vendor-tools-page .status-failed {
border-color: var(--momo-danger-border);
background: var(--momo-danger-bg);
color: var(--momo-danger-text);
}
.vendor-tools-page .status-pending {
border-color: var(--momo-warning-border);
background: var(--momo-warning-bg);
color: var(--momo-warning-text);
}
.vendor-tools-page .upload-area {
border: 1px dashed var(--momo-page-accent-line) !important;
border-radius: var(--momo-radius-md) !important;
padding: clamp(1.2rem, 4vw, 2.6rem) !important;
background:
radial-gradient(circle at 10px 10px, rgba(172, 92, 58, 0.13) 1.1px, transparent 1.3px) 0 0 / 16px 16px,
var(--momo-bg-elevated) !important;
cursor: pointer;
}
.vendor-tools-page .upload-area:hover,
.vendor-tools-page .upload-area.dragover {
border-color: var(--momo-page-accent-dark) !important;
background-color: var(--momo-page-accent-soft) !important;
transform: none !important;
}
.vendor-tools-page .upload-icon {
color: var(--momo-page-accent-dark) !important;
}
.vendor-tools-page .modal-header {
border-bottom: 1px solid var(--momo-border-light);
background: var(--momo-text-primary) !important;
color: var(--momo-bg-paper) !important;
}
.vendor-tools-page .modal-content {
border: 1px solid var(--momo-border-light);
border-radius: var(--momo-radius-md);
background: var(--momo-bg-surface);
}
.vendor-tools-page .alert-info {
border-color: var(--momo-info-border);
background: var(--momo-info-bg);
color: var(--momo-info-text);
}
.vendor-tools-page .alert-danger {
border-color: var(--momo-danger-border);
background: var(--momo-danger-bg);
color: var(--momo-danger-text);
}
@media (max-width: 900px) {
.vendor-tools-header {
grid-template-columns: 1fr;
align-items: start;
padding: var(--momo-space-4);
}
.vendor-tools-nav {
justify-content: flex-start;
}
}
@media (max-width: 760px) {
.vendor-tools-page {
gap: var(--momo-space-4);
}
.vendor-tools-header {
border-radius: var(--momo-radius-md);
}
.vendor-tools-nav a {
flex: 1 1 calc(50% - 8px);
justify-content: center;
}
.vendor-tools-page .row {
row-gap: var(--momo-space-3);
}
.vendor-tools-page .table-container {
padding: 10px;
}
.vendor-tools-page .table {
min-width: 0;
}
.vendor-tools-page .table-container .table-responsive {
overflow-x: visible;
}
.vendor-tools-page .table-container table,
.vendor-tools-page .table-container tbody,
.vendor-tools-page .table-container tr,
.vendor-tools-page .table-container td {
display: block;
width: 100%;
}
.vendor-tools-page .table-container thead {
display: none;
}
.vendor-tools-page .table-container tbody {
display: grid;
gap: 10px;
}
.vendor-tools-page .table-container tbody tr {
overflow: hidden;
border: 1px solid var(--momo-border-light);
border-radius: var(--momo-radius-sm);
background: var(--momo-bg-elevated);
}
.vendor-tools-page .table-container tbody td {
display: grid;
grid-template-columns: 5.8rem minmax(0, 1fr);
gap: 10px;
min-height: 40px;
padding: 10px 12px;
border-bottom: 1px solid var(--momo-border-light);
text-align: left !important;
overflow-wrap: anywhere;
}
.vendor-tools-page .table-container tbody td:last-child {
border-bottom: 0;
}
.vendor-tools-page .table-container tbody td::before {
color: var(--momo-text-tertiary);
font-family: var(--momo-font-mono);
font-size: 0.74rem;
font-weight: 800;
}
.vendor-tools-page .table-container tbody td[colspan] {
display: block;
}
.vendor-tools-page .table-container tbody td[colspan]::before {
content: none;
}
.vendor-tools-page[data-vendor-tool="management"] .table-container tbody td:nth-child(1)::before { content: "代碼"; }
.vendor-tools-page[data-vendor-tool="management"] .table-container tbody td:nth-child(2)::before { content: "廠商"; }
.vendor-tools-page[data-vendor-tool="management"] .table-container tbody td:nth-child(3)::before { content: "郵件"; }
.vendor-tools-page[data-vendor-tool="management"] .table-container tbody td:nth-child(4)::before { content: "數量"; }
.vendor-tools-page[data-vendor-tool="management"] .table-container tbody td:nth-child(5)::before { content: "操作"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(1)::before { content: "ID"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(2)::before { content: "批次"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(3)::before { content: "廠商"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(4)::before { content: "收件"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(5)::before { content: "主旨"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(6)::before { content: "商品"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(7)::before { content: "狀態"; }
.vendor-tools-page[data-vendor-tool="email"] .table-container tbody td:nth-child(8)::before { content: "時間"; }
}
@media (max-width: 520px) {
.vendor-tools-nav a {
flex-basis: 100%;
}
.vendor-tools-page .d-flex.justify-content-between {
align-items: stretch !important;
flex-direction: column;
gap: 10px;
}
}