/* ============================================== 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; }