.tableContainer { background-color: var(--card-bg); border-color: var(--border-color); border-radius: 0.5rem; padding: 1.5rem; box-shadow: var(--card-shadow); margin-bottom: 2rem; } .tableTitle { margin-top: 0; margin-bottom: 1.5rem; color: var(--text-primary); font-size: 1.25rem; } .tableWrapper { width: 100%; overflow-x: auto; } .analyticsTable { width: 100%; border-collapse: collapse; font-size: 0.875rem; } .analyticsTable th { text-align: left; padding: 0.75rem 1rem; color: var(--text-primary); font-weight: 600; border-bottom: 2px solid var(--border-color); } .analyticsTable td { padding: 0.75rem 1rem; border-bottom: 1px solid var(--border-color); color: var(--text-primary); vertical-align: top; } .analyticsTable tr:last-child td { border-bottom: none; } .analyticsTable tr:hover td { background-color: var(--hover-bg); } .expandedRow td { background-color: var(--hover-bg) !important; } .secondaryInfo { font-size: 0.75rem; color: var(--text-secondary); margin-top: 0.25rem; } .actions { display: flex; align-items: center; gap: 0.5rem; } .expandButton { background-color: transparent; color: var(--text-primary); border: 1px solid var(--border-color); border-radius: 0.25rem; width: 1.685rem; height: 1.685rem; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 1rem; line-height: 1; padding: 0; } .expandButton:hover { background-color: var(--border-color); } .deleteButton { background-color: transparent; color: var(--text-primary); border: 1px solid var(--border-color); border-radius: 0.25rem; padding: 0.25rem 0.5rem; font-size: 0.75rem; cursor: pointer; } .deleteButton:hover { background-color: var(--border-color); color: white; } .expandedDetails { margin-top: 1rem; border-top: 1px solid var(--border-color); padding-top: 1rem; } .detailsCard { background-color: var(--card-secondary-bg); border-radius: 0.375rem; padding: 1rem; margin-bottom: 1rem; } .detailsCard h4 { margin-top: 0; margin-bottom: 1rem; color: var(--text-primary); font-size: 1rem; } .detailsGrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 1rem; } .detailsGrid > div { margin-bottom: 0.5rem; } .detailsGrid strong { display: block; color: var(--text-secondary); font-size: 0.75rem; margin-bottom: 0.25rem; } .detailValue { color: var(--text-primary); font-size: 0.875rem; word-break: break-all; } .pagination { display: flex; justify-content: center; align-items: center; margin-top: 1.5rem; gap: 1rem; } .pageButton { background-color: var(--primary-color); color: white; border: none; border-radius: 0.25rem; padding: 0.5rem 1rem; cursor: pointer; } .pageButton:hover:not(:disabled) { background-color: var(--primary-dark); } .pageButton:disabled { background-color: var(--disabled-bg); color: var(--disabled-text); cursor: not-allowed; } .pageInfo { color: var(--text-secondary); } @media (max-width: 768px) { .tableContainer { padding: 1rem; } .analyticsTable th, .analyticsTable td { padding: 0.5rem; } .detailsGrid { grid-template-columns: 1fr; } } .tableHeader { display: flex; flex-direction: row; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; margin-bottom: 1rem; } .searchContainer { position: relative; flex: 1; max-width: 300px; } .searchInput { width: 100%; padding: 0.5rem 2rem 0.5rem 0.75rem; border: 1px solid var(--border-color); border-radius: 0.25rem; background-color: var(--input-bg); color: var(--text-primary); font-size: 0.875rem; } .searchInput:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.2); } .clearSearchButton { position: absolute; right: 0.5rem; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--text-secondary); cursor: pointer; font-size: 0.875rem; padding: 0.25rem; border-radius: 50%; } .clearSearchButton:hover { color: var(--text-primary); background-color: var(--hover-bg); } .searchResults { margin-bottom: 1rem; padding: 0.5rem; border-radius: 0.25rem; font-size: 0.875rem; color: var(--text-secondary); } .noResults { padding: 2rem; text-align: center; color: var(--text-secondary); font-style: italic; } @media (max-width: 640px) { .tableHeader { flex-direction: column; align-items: flex-start; } .searchContainer { max-width: 100%; width: 100%; } }