.table-container {
    overflow-x: auto;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
    border-radius: 0 0 8px 8px;
    margin-bottom: 40px;
    background: white;
}

table { width: 100%; border-collapse: collapse; }

th {
    background-color: #334155; /* Ваш колір */
    color: #f8fafc;
    text-align: left;
    padding: 15px;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.05em;
    border-bottom: 2px solid #475569;
}

td { padding: 12px 15px; border-bottom: 1px solid #e2e8f0; font-size: 14px; vertical-align: top; }

tr:last-child td { border-bottom: none; }
tr:nth-child(even) { background-color: #f8fafc; }
tr:hover { background-color: #f1f5f9; transition: 0.2s; }

.badge {
    background: #e2e8f0;
    padding: 2px 8px;
    border-radius: 4px;
    font-family: 'Courier New', monospace;
    font-size: 12px;
    color: #475569;
    font-weight: bold;
}

.required {
    color: #ef4444;
    font-weight: bold;
    font-size: 10px;
    text-transform: uppercase;
    display: block;
    margin-top: 4px;
}

.type-id { color: #0ea5e9; font-weight: 600; font-family: monospace; }