table {
    width: 100%;
    border-collapse: separate; /* change from collapse */
    border-spacing: 0;         /* ensure borders stay tight */
    margin: 20px 0;
    table-layout: auto;
    border-radius: 10px;        /* add rounded corners */
    overflow: hidden; 
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

th, td {
    padding: 12px;
    text-align: left;
    word-wrap: break-word;
    border: 1px solid #ddd;
    font-family: Inter, sans-serif;
    font-size: 1.125rem;
}

#data-table th,
#data-table td {
  text-align: left !important;
}

#data-table {
  table-layout: auto !important;
  width: 100% !important;
}

th {
    background-color: #d9b5e4;
    text-align: center;
}

tr:nth-child(even) {
    background-color: #f9f9f9;
}

tr:hover td{
    background-color: #f1f1f1;
}

td {
    transition: background-color 0.1s ease;
}

div.dt-buttons button.btn {
  padding: 4px 8px;
  font-size: 1.1rem !important;
  height: 40px;
  line-height: 1;
  min-width: 28px;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  text-align: center;
  background-color: #d9b5e4;
  font-family: Inter, sans-serif;
  color: #fff;
  border: 1px solid black;
  cursor: pointer;
  margin-right: 8px;
  margin-top: 10px;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

/* Hover effect for individual buttons */
div.dt-buttons button.btn:hover,
div.dt-buttons button.btn.dt-button:hover{
  background-color: #9957b3;
  box-shadow: 4px 6px 12px rgba(0, 0, 0, 0.3);
  transform: translateY(-1px);
}

/* Container styling only (no hover!) */
.dt-buttons {
  float: right !important;
  margin-bottom: 10px;
  display: flex;
  gap: 8px; /* spacing between buttons */
}

/* shown X entries */
.dataTables_length {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  margin-bottom: 10px;
  margin-top: 10px;
  color: #2c3e50;
}


.dataTables_length select {
  padding: 5px 10px;
  font-size: 20px;
  border-radius: 4px;
  border: 1px solid #ccc;
  background-color: #fff;
  color: #333;
}


.dataTables_length label {
  display: flex;
  align-items: center;
  gap: 8px;
}


#data-table th.narrow-date-column,
#data-table td:nth-child(1) {
    white-space: normal !important;  
    word-wrap: break-word;           
    overflow-wrap: break-word;
    max-width: 150px;             
    text-align: center;
}
