/* Variables */ :root { --bg-primary: #f5f7fa; --bg-secondary: #ffffff; --text-primary: #2c3e50; --text-secondary: #4a5568; --border-color: #eee; --shadow: 0 2px 4px rgba(0,0,0,0.1); --hover-bg: #f8f9fa; --priority-1: #ff4d4d; --priority-2: #ffa726; --priority-3: #42a5f5; --priority-4: #66bb6a; /* Spacing */ --spacing-xs: 0.5rem; --spacing-sm: 1rem; --spacing-md: 1.5rem; --spacing-lg: 2rem; /* Transitions */ --transition-default: all 0.3s ease; } /* Dark theme */ [data-theme="dark"] { --bg-primary: #1a202c; --bg-secondary: #2d3748; --text-primary: #f7fafc; --text-secondary: #e2e8f0; --border-color: #4a5568; --shadow: 0 2px 4px rgba(0,0,0,0.3); --hover-bg: #374151; --priority-1: #7f1d1d; --priority-2: #854d0e; --priority-3: #075985; --priority-4: #166534; } /* Base Elements */ body { font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; margin: 0; padding: var(--spacing-md); background-color: var(--bg-primary); color: var(--text-primary); transition: var(--transition-default); } /* Reusable Components */ .card-base { background: var(--bg-secondary); border-radius: 12px; box-shadow: var(--shadow); padding: var(--spacing-md); } .btn-base { padding: var(--spacing-sm) var(--spacing-md); border-radius: 6px; border: none; cursor: pointer; transition: var(--transition-default); } .btn-primary { background: #3b82f6; color: white; } /* Layout Components */ .dashboard-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--spacing-md); margin-left: 3.75rem; } .ticket-container { max-width: 800px; margin: var(--spacing-lg) auto; border-left: 6px solid; transition: var(--transition-default); } .flex-row { display: flex; gap: var(--spacing-sm); } .flex-between { justify-content: space-between; align-items: center; } /* Table Styles */ .table-base { width: 100%; border-collapse: separate; border-spacing: 0; overflow: hidden; } .table-cell { padding: var(--spacing-md); text-align: left; border-bottom: 1px solid var(--border-color); } /* Priority Styles */ .priority-indicator { font-weight: bold; font-family: 'Courier New', monospace; padding: var(--spacing-xs) var(--spacing-sm); border-radius: 4px; display: inline-block; } .priority-1 { color: var(--priority-1); } .priority-2 { color: var(--priority-2); } .priority-3 { color: var(--priority-3); } .priority-4 { color: var(--priority-4); } /* Status Styles */ .status-base { font-weight: bold; padding: var(--spacing-xs) var(--spacing-sm); border-radius: 4px; } .status-Open { color: #10b981; background: rgba(16, 185, 129, 0.1); } .status-Closed { color: #ef4444; background: rgba(239, 68, 68, 0.1); } .status-dropdown { position: relative; display: inline-block; margin-right: 15px; } .dropdown-header { padding: 8px 15px; background: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: 4px; cursor: pointer; min-width: 120px; } .dropdown-content { display: none; position: absolute; top: 100%; left: 0; background: var(--bg-secondary); min-width: 160px; box-shadow: var(--shadow); border-radius: 4px; padding: 10px; z-index: 100; border: 1px solid var(--border-color); } .status-dropdown.active .dropdown-content { display: block; } .dropdown-content label { display: block; padding: 8px; cursor: pointer; transition: background 0.2s; } .dropdown-content label:hover { background: var(--hover-bg); } .dropdown-content .save-filter { margin-top: 10px; width: 100%; padding: 8px; background: #3b82f6; color: white; border: none; border-radius: 4px; cursor: pointer; } /*UNCHECKED BELOW*/ body.menu-open { padding-left: 260px; } .create-ticket { background: #3b82f6; color: white; padding: 0.625rem 1.25rem; border-radius: 0.375rem; border: none; cursor: pointer; font-weight: 500; transition: background-color 0.3s ease; margin-right: 3.75rem; } .create-ticket:hover { background: #2563eb; } h1 { color: var(--text-primary); margin: 0; } table { width: 100%; border-collapse: separate; border-spacing: 0; background: var(--bg-secondary); border-radius: 12px; box-shadow: var(--shadow); overflow: hidden; } th, td { padding: 16px; text-align: left; border-bottom: 1px solid var(--border-color); color: var(--text-primary); } th { background-color: var(--bg-secondary); font-weight: 600; text-transform: uppercase; font-size: 0.9em; letter-spacing: 0.05em; } tr:hover { background-color: var(--hover-bg); } tbody tr td:first-child { border-left: 6px solid; } tbody tr.priority-1 td:first-child { border-left-color: var(--priority-1); } tbody tr.priority-2 td:first-child { border-left-color: var(--priority-2); } tbody tr.priority-3 td:first-child { border-left-color: var(--priority-3); } tbody tr.priority-4 td:first-child { border-left-color: var(--priority-4); } /* Priority number styling */ td:nth-child(2) { text-align: center; } td:nth-child(2) span { font-weight: bold; font-family: 'Courier New', monospace; padding: 4px 8px; border-radius: 4px; display: inline-block; background: var(--hover-bg); } .priority-1 td:nth-child(2) { color: var(--priority-1); } .priority-2 td:nth-child(2) { color: var(--priority-2); } .priority-3 td:nth-child(2) { color: var(--priority-3); } .priority-4 td:nth-child(2) { color: var(--priority-4); } .search-box { padding: 0.5rem 0.75rem; border: 1px solid var(--border-color); border-radius: 0.375rem; background: var(--bg-secondary); color: var(--text-primary); margin-left: 1.25rem; width: 40%; } .status-filter { padding: 0.5rem 0.75rem; border: 1px solid var(--border-color); border-radius: 0.375rem; background: var(--bg-secondary); color: var(--text-primary); cursor: pointer; min-width: 120px; margin-right: 1rem; } .search-box:focus, .status-filter:focus { outline: none; border-color: #3b82f6; box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1); } .theme-toggle { position: absolute; top: 20px; right: 20px; z-index: 100; padding: 12px; border-radius: 50%; background: var(--bg-secondary); border: 1px solid var(--border-color); cursor: pointer; box-shadow: var(--shadow); font-size: 1.2em; transition: transform 0.3s ease; } .theme-toggle:hover { transform: scale(1.1); } .table-controls { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; padding: 10px; background: var(--bg-secondary); border-radius: 8px; box-shadow: var(--shadow); } .ticket-count { font-weight: 500; color: var(--text-secondary); } .table-actions { display: flex; gap: 15px; align-items: center; } .pagination { display: flex; gap: 0.5rem; align-items: center; } .pagination button { padding: 0.5rem 0.75rem; border: 1px solid var(--border-color); background: var(--bg-secondary); color: var(--text-primary); border-radius: 0.375rem; cursor: pointer; transition: all 0.2s ease; } .pagination button:hover { background: var(--hover-bg); } .pagination button.active { background: #3b82f6; color: white; border-color: #3b82f6; } .settings-icon { cursor: pointer; padding: 8px; border-radius: 4px; transition: background-color 0.2s; } .settings-icon:hover { background: var(--hover-bg); } /* Settings Modal Styles */ .settings-modal-backdrop { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); display: flex; justify-content: center; align-items: center; z-index: 1000; } .settings-modal { background: var(--bg-secondary); border-radius: 12px; width: 500px; max-width: 90%; box-shadow: var(--shadow); padding: 20px; } .settings-modal-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--border-color); padding-bottom: 15px; margin-bottom: 15px; } .settings-modal-header h2 { margin: 0; color: var(--text-primary); } .close-modal { background: none; border: none; font-size: 24px; cursor: pointer; color: var(--text-secondary); } .setting-group { margin-bottom: 15px; } .setting-group label { display: block; margin-bottom: 8px; color: var(--text-primary); } .setting-group select { width: 100%; padding: 10px; border: 1px solid var(--border-color); border-radius: 6px; background: var(--bg-primary); color: var(--text-primary); } .settings-modal-footer { display: flex; justify-content: flex-end; gap: 10px; border-top: 1px solid var(--border-color); padding-top: 15px; } .save-settings, .cancel-settings { padding: 10px 20px; border-radius: 6px; border: none; cursor: pointer; transition: background-color 0.3s ease; } .save-settings { background: #3b82f6; color: white; } .cancel-settings { background: var(--hover-bg); color: var(--text-primary); } /* Sorting indicator styles */ th { position: relative; /* Ensure proper positioning of arrows */ cursor: pointer; /* Show it's clickable */ } th::after { content: ''; position: absolute; right: 8px; top: 50%; transform: translateY(-50%); width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; opacity: 0.5; /* Make arrows less prominent when not active */ } th.sort-asc::after { border-bottom: 7px solid var(--text-primary); opacity: 1; } th.sort-desc::after { border-top: 7px solid var(--text-primary); opacity: 1; } /* Column toggle styles */ .column-toggles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; } .column-toggles label { display: flex; align-items: center; gap: 8px; } .hamburger-menu { position: absolute; top: 20px; left: 20px; z-index: 100; } .hamburger-icon { cursor: pointer; font-size: 24px; background: var(--bg-secondary); padding: 10px; border-radius: 4px; box-shadow: var(--shadow); } .hamburger-content { position: fixed; top: 0; left: -250px; width: 200px; height: 100%; background: var(--bg-secondary); box-shadow: 2px 0 5px rgba(0,0,0,0.1); transition: left 0.3s ease, margin-left 0.3s ease; padding: 40px 20px 20px; overflow-y: auto; z-index: 99; } .hamburger-content.open { left: 0; } .close-hamburger { position: absolute; top: 10px; right: 10px; cursor: pointer; font-size: 24px; background: var(--bg-secondary); padding: 10px; border-radius: 4px; box-shadow: var(--shadow); } .filter-section { margin-bottom: 20px; } .filter-section label { display: block; margin-bottom: 10px; } .filter-actions { display: flex; gap: 10px; } .filter-actions button { flex: 1; padding: 10px; border: none; border-radius: 4px; cursor: pointer; } #apply-filters { background: #3b82f6; color: white; } #clear-filters { background: var(--hover-bg); color: var(--text-primary); } .ticket-link { font-family: 'Courier New', monospace; font-weight: bold; color: var(--text-primary) !important; text-decoration: none; background: var(--hover-bg); padding: 4px 8px; border-radius: 4px; display: inline-block; } .ticket-link:hover { background: var(--border-color); } /* Hamburger Menu Styles */ .menu-group { margin-bottom: 20px; padding: 15px; border-bottom: 1px solid var(--border-color); } .menu-group label { display: block; margin-bottom: 8px; color: var(--text-secondary); font-weight: 500; } .menu-group select { width: 100%; padding: 10px; border: 1px solid var(--border-color); border-radius: 6px; background: var(--bg-primary); color: var(--text-primary); transition: all 0.3s ease; } .menu-actions { padding: 15px; text-align: center; } .menu-actions .btn.primary { width: 100%; padding: 12px; font-weight: 500; } .menu-controls { padding: 15px; text-align: center; border-bottom: 1px solid var(--border-color); } .menu-controls .btn { width: 100%; padding: 12px; font-weight: 500; }