PUMS-TOOLKIT / static /theme.css
ndmhung6's picture
style: establish visually distinct hierarchies for main categories, tool items, and tree sub-links
940a276
Raw
History Blame Contribute Delete
14.6 kB
/* ==============================================
PUMS TOOLKIT — DESIGN TOKENS
Sửa các giá trị ở đây để thay đổi toàn bộ giao diện
============================================== */
:root {
/* --- Màu chính --- */
--color-primary: #4361ee;
--color-primary-dark: #3730a3;
--color-primary-light: #f0f3ff;
--color-primary-hover: #eef2ff;
/* --- Màu nền --- */
--color-bg-page: #f5f7fa;
--color-bg-sidebar: #ffffff;
--color-bg-card: #ffffff;
--color-bg-input: #f8fafc;
/* --- Màu chữ --- */
--color-text-heading: #1e293b;
--color-text-body: #334155;
--color-text-muted: #64748b;
--color-text-disabled: #cbd5e1;
/* --- Màu border --- */
--color-border: #e8ecf0;
--color-border-light: #f0f2f5;
--color-border-input: #e2e8f0;
/* --- Màu trạng thái nav active --- */
--color-nav-active-bg: #f0f3ff;
--color-nav-active-txt: #4361ee;
/* --- Màu label section "sắp có" --- */
--color-label-muted: #94a3b8;
/* --- Typography --- */
--font-family: 'Inter', sans-serif;
--font-size-base: 0.875rem;
--font-size-sm: 0.75rem;
--font-size-xs: 0.68rem;
--font-weight-normal: 400;
--font-weight-semi: 600;
--font-weight-bold: 800;
/* --- Spacing --- */
--spacing-xs: 0.25rem;
--spacing-sm: 0.5rem;
--spacing-md: 1rem;
--spacing-lg: 1.5rem;
--spacing-xl: 2rem;
/* --- Border radius --- */
--radius-sm: 6px;
--radius-md: 10px;
--radius-lg: 16px;
--radius-xl: 20px;
/* --- Shadow --- */
--shadow-card: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
--shadow-btn: 0 4px 12px rgba(67, 97, 238, 0.25);
/* --- Kích thước sidebar --- */
--sidebar-width: 260px;
}
/* ==============================================
BASE STYLES
============================================== */
body {
background-color: var(--color-bg-page);
font-family: var(--font-family);
font-size: var(--font-size-base);
color: var(--color-text-body);
display: flex;
min-height: 100vh;
}
/* ==============================================
SIDEBAR
============================================== */
.sidebar {
width: var(--sidebar-width);
background: var(--color-bg-sidebar);
border-right: 1px solid var(--color-border);
padding: var(--spacing-lg) calc(var(--spacing-lg) * 0.8);
flex-shrink: 0;
overflow-y: auto;
height: 100vh;
position: sticky;
top: 0;
}
/* --- Brand / Logo --- */
.brand {
display: flex;
align-items: center;
gap: 10px;
margin-bottom: var(--spacing-xl);
padding-bottom: var(--spacing-lg);
border-bottom: 1px solid var(--color-border-light);
}
.brand img {
width: 36px;
height: 36px;
object-fit: contain;
mix-blend-mode: multiply;
}
.brand-name {
font-weight: var(--font-weight-bold);
font-size: 0.95rem;
color: var(--color-text-heading);
letter-spacing: 0.04em;
}
/* --- Navigation --- */
.nav-link {
padding: 0.65rem 0.9rem;
border-radius: var(--radius-md);
color: var(--color-text-muted);
font-weight: var(--font-weight-semi);
font-size: var(--font-size-base);
margin-bottom: 0.2rem;
transition: background 0.15s, color 0.15s;
display: flex;
align-items: center;
gap: 10px;
}
.nav-link:hover {
background: var(--color-bg-input);
color: var(--color-text-heading);
}
.nav-link.active {
background: var(--color-nav-active-bg);
color: var(--color-nav-active-txt);
}
.nav-link i {
width: 16px;
font-size: 0.85rem;
}
/* --- Sub nav (children of a nav item) --- */
.nav-sub {
padding-left: 1rem;
border-left: 1.5px dashed var(--color-border-input);
margin-left: 1.5rem;
margin-bottom: 0.4rem;
margin-top: 0.2rem;
}
.nav-link-sub {
font-size: 0.78rem;
padding: 0.4rem 0.65rem;
color: var(--color-text-muted);
font-weight: 500;
position: relative;
display: flex;
align-items: center;
gap: 6px;
border-radius: var(--radius-sm);
}
.nav-link-sub::before {
content: "•";
color: var(--color-text-disabled);
font-size: 0.8rem;
margin-right: 2px;
transition: color 0.15s;
}
.nav-link-sub:hover {
color: var(--color-text-heading);
background: var(--color-bg-input);
}
.nav-link-sub:hover::before,
.nav-link-sub.active::before {
color: var(--color-primary);
}
.nav-link-sub.active {
background: var(--color-nav-active-bg);
color: var(--color-nav-active-txt);
font-weight: 600;
}
/* --- Collapsible nav item --- */
.nav-link-collapsible {
justify-content: space-between;
}
.nav-chevron {
font-size: 0.7rem;
transition: transform 0.2s ease;
color: var(--color-text-disabled);
}
.nav-chevron.collapsed {
transform: rotate(-90deg);
}
.nav-section-header {
font-size: 0.68rem;
text-transform: uppercase;
color: var(--color-text-heading);
font-weight: 800;
letter-spacing: 0.08em;
padding: 8px 12px;
display: flex;
justify-content: space-between;
align-items: center;
cursor: pointer;
border-radius: var(--radius-sm);
background: var(--color-bg-input);
border-left: 3px solid var(--color-primary);
transition: all 0.15s ease;
margin-top: 1.2rem;
margin-bottom: 0.4rem;
}
.nav-section-header:hover {
background: var(--color-border-input);
color: #000;
}
.nav-section-header .nav-chevron {
font-size: 0.62rem;
color: var(--color-text-muted);
transition: transform 0.2s ease;
}
.nav-section-header.collapsed .nav-chevron {
transform: rotate(-90deg);
}
.nav-link.disabled {
color: var(--color-text-disabled);
cursor: not-allowed;
pointer-events: none;
}
/* ==============================================
MAIN CONTENT
============================================== */
.main-content {
flex-grow: 1;
padding: var(--spacing-xl);
max-width: 1200px;
margin: 0 auto;
}
/* ==============================================
CARD
============================================== */
.card-custom {
border: none;
border-radius: var(--radius-lg);
box-shadow: var(--shadow-card);
background: var(--color-bg-card);
}
/* ==============================================
BUTTONS
============================================== */
.btn-primary-custom {
background: var(--color-primary);
border: none;
color: #ffffff;
padding: 14px 40px;
border-radius: var(--radius-md);
font-weight: var(--font-weight-bold);
font-size: var(--font-size-base);
width: 100%;
transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
cursor: pointer;
}
.btn-primary-custom:hover {
background: var(--color-primary-dark);
transform: translateY(-2px);
box-shadow: var(--shadow-btn);
}
/* ==============================================
FORM ELEMENTS
============================================== */
.form-control,
.form-select {
border-color: var(--color-border-input);
border-radius: var(--radius-md);
font-size: var(--font-size-base);
background-color: var(--color-bg-card);
color: var(--color-text-body);
transition: border-color 0.15s, box-shadow 0.15s;
}
.form-control:focus,
.form-select:focus {
border-color: var(--color-primary);
box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1);
outline: none;
}
.form-label {
font-weight: var(--font-weight-semi);
font-size: var(--font-size-sm);
color: var(--color-text-muted);
margin-bottom: var(--spacing-xs);
}
/* ==============================================
FILE UPLOAD
============================================== */
.file-upload-wrapper {
border: 2px dashed var(--color-border-input);
border-radius: var(--radius-lg);
padding: 40px;
text-align: center;
background: var(--color-bg-input);
cursor: pointer;
transition: border-color 0.2s, background 0.2s;
}
.file-upload-wrapper:hover {
border-color: var(--color-primary);
background: var(--color-primary-hover);
}
/* ==============================================
NAV PILLS (tabs)
============================================== */
.nav-pills .nav-link {
border-radius: var(--radius-md);
padding: 10px 20px;
font-weight: var(--font-weight-semi);
color: var(--color-text-muted);
border: 1px solid transparent;
transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.nav-pills .nav-link:hover:not(.active) {
background: var(--color-primary-light);
color: var(--color-primary);
border-color: var(--color-primary-light);
}
.nav-pills .nav-link.active {
background-color: var(--color-primary);
color: #ffffff;
border-color: var(--color-primary);
box-shadow: 0 2px 8px rgba(67, 97, 238, 0.25);
}
/* ==============================================
SPINNER / LOADER
============================================== */
.loader-overlay {
display: none;
position: fixed;
top: 0; left: 0;
width: 100%; height: 100%;
background: rgba(255, 255, 255, 0.85);
z-index: 1000;
justify-content: center;
align-items: center;
flex-direction: column;
}
.spinner-pro {
width: 48px;
height: 48px;
border: 4px solid var(--color-border);
border-top: 4px solid var(--color-primary);
border-radius: 50%;
animation: spin 0.9s linear infinite;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
/* ==============================================
SELECT2 GLOBAL PREMIUM STYLES
============================================== */
/* Container box style */
.select2-container--default .select2-selection--single {
border: 1px solid var(--color-border-input) !important;
border-radius: var(--radius-md) !important;
height: 38px !important;
padding: 5px 12px !important;
background-color: var(--color-bg-card) !important;
color: var(--color-text-body) !important;
font-family: var(--font-family) !important;
font-size: var(--font-size-base) !important;
display: flex !important;
align-items: center !important;
transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
}
/* Container focus state */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
border-color: var(--color-primary) !important;
box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.1) !important;
outline: none !important;
}
/* Chosen value styling */
.select2-container--default .select2-selection--single .select2-selection__rendered {
color: var(--color-text-body) !important;
padding-left: 0 !important;
line-height: 26px !important;
font-weight: 500 !important;
width: 100% !important;
}
/* Arrow indicator styling */
.select2-container--default .select2-selection--single .select2-selection__arrow {
height: 36px !important;
right: 8px !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
border-color: var(--color-text-muted) transparent transparent transparent !important;
border-width: 5px 4px 0 4px !important;
}
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
border-color: transparent transparent var(--color-text-muted) transparent !important;
border-width: 0 4px 5px 4px !important;
}
/* Dropdown overlay styling */
.select2-dropdown {
border: 1px solid var(--color-border) !important;
border-radius: var(--radius-lg) !important;
box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1) !important;
background-color: var(--color-bg-card) !important;
font-size: var(--font-size-base) !important;
overflow: hidden !important;
z-index: 1050 !important;
}
/* Search input container within dropdown */
.select2-search--dropdown {
padding: 8px 12px !important;
background: #f8fafc !important;
border-bottom: 1px solid var(--color-border-light) !important;
}
.select2-search--dropdown .select2-search__field {
border: 1px solid var(--color-border-input) !important;
border-radius: var(--radius-sm) !important;
padding: 6px 10px !important;
outline: none !important;
font-size: var(--font-size-sm) !important;
background-color: #fff !important;
}
.select2-search--dropdown .select2-search__field:focus {
border-color: var(--color-primary) !important;
box-shadow: 0 0 0 3px rgba(67, 97, 238, 0.08) !important;
}
/* Results options list container */
.select2-results__options {
padding: 6px !important;
max-height: 250px !important;
}
/* Individual list item styling */
.select2-results__option {
padding: 8px 12px !important;
border-radius: var(--radius-sm) !important;
color: var(--color-text-body) !important;
font-size: var(--font-size-base) !important;
transition: background 0.1s, color 0.1s !important;
margin-bottom: 2px !important;
}
/* Hover/active option styling */
.select2-results__option--highlighted[aria-selected] {
background-color: var(--color-primary) !important;
color: #ffffff !important;
}
/* Selected option styling */
.select2-container--default .select2-results__option[aria-selected="true"] {
background-color: var(--color-primary-light) !important;
color: var(--color-primary) !important;
font-weight: 600 !important;
}
/* Optgroup styling headers */
.select2-results__group {
font-size: 0.72rem !important;
font-weight: 700 !important;
text-transform: uppercase !important;
letter-spacing: 0.06em !important;
color: var(--color-text-muted) !important;
padding: 8px 12px 4px !important;
}
/* Custom Scrollbar for Select2 options */
.select2-results__options::-webkit-scrollbar {
width: 6px;
}
.select2-results__options::-webkit-scrollbar-track {
background: transparent;
}
.select2-results__options::-webkit-scrollbar-thumb {
background-color: #cbd5e1;
border-radius: 10px;
}
.select2-results__options::-webkit-scrollbar-thumb:hover {
background-color: #94a3b8;
}
/* Sidebar sub-group collapsible spacing */
.nav-sub-group.collapse.show {
margin-bottom: 0.8rem;
}