.fv-profile-table {
    width: 100%;
    max-width: 600px;
    border-collapse: collapse;
    margin: 20px 0;
    font-size: 16px;
}

.fv-profile-table td {
    border-bottom: 1px solid #ddd;
    padding: 8px 10px;
}

.fv-profile-table td:first-child {
    font-weight: 600;
    color: #333;
    width: 40%;
}

@media (max-width: 600px) {
    .fv-profile-table,
    .fv-profile-table tbody,
    .fv-profile-table tr,
    .fv-profile-table td {
        display: block;
        width: 100%;
    }
    .fv-profile-table tr {
        margin-bottom: 10px;
        border: 1px solid #e0e0e0;
        border-radius: 8px;
        padding: 10px;
        background: #fafafa;
    }
    .fv-profile-table td:first-child {
        color: #666;
        font-size: 14px;
        margin-bottom: 5px;
        display: block;
    }
    .fv-profile-table td:last-child {
        font-size: 15px;
        display: block;
    }
}

.fv-profile-link {
    display: inline-block;
    margin-top: 15px;
    padding: 8px 16px;
    background: #0073aa;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    transition: background 0.2s ease;
}

.fv-profile-link:hover {
    background: #005c87;
}

/* Tabelle im Zeilen - Layout mit Optimierung für Smartphones
 * Für Mobile müssen die <td> jeweils ein data-label bekommen:
 * <td data-label="Name"><?php echo esc_html($row['name']); ?></td>
 * <td data-label="Gewässer"><?php echo esc_html($row['gewaesser']); ?></td>
 * <td data-label="Datum"><?php echo esc_html($row['datum']); ?></td>
 * Selektor: id="fv-table-mobile-desktop"
 */ 

/* Tabelle Desktop + Mobile */
#fv-table-mobile-desktop {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 15px;
	line-height: 1.4;
	background: #fff;
}

#fv-table-mobile-desktop th,
#fv-table-mobile-desktop td {
	padding: 10px 12px;
	border: 1px solid #ddd;
	text-align: left;
	vertical-align: top;
}

#fv-table-mobile-desktop th {
	background: #f4f4f4;
	font-weight: 600;
}

#fv-table-mobile-desktop tr:nth-child(even) {
	background: #fafafa;
}

#fv-table-mobile-desktop tr:hover {
	background: #f1f7ff;
}

/* Optionaler Wrapper für horizontales Scrollen */
.fv-table-wrapper {
	width: 100%;
	overflow-x: auto;
}

/* Smartphone-Optimierung */
@media (max-width: 768px) {

	#fv-table-mobile-desktop,
	#fv-table-mobile-desktop thead,
	#fv-table-mobile-desktop tbody,
	#fv-table-mobile-desktop th,
	#fv-table-mobile-desktop td,
	#fv-table-mobile-desktop tr {
		display: block;
		width: 100%;
	}

	#fv-table-mobile-desktop thead {
		display: none;
	}

	#fv-table-mobile-desktop tr {
		margin-bottom: 14px;
		border: 1px solid #ddd;
		border-radius: 8px;
		background: #fff;
		overflow: hidden;
	}

	#fv-table-mobile-desktop td {
		display: flex;
		justify-content: space-between;
		gap: 12px;
		padding: 10px 12px;
		border: none;
		border-bottom: 1px solid #eee;
		text-align: right;
	}

	#fv-table-mobile-desktop td:last-child {
		border-bottom: none;
	}

	#fv-table-mobile-desktop td::before {
		content: attr(data-label);
		font-weight: 600;
		text-align: left;
		color: #333;
	}

	#fv-table-mobile-desktop tr:hover {
		background: #fff;
	}
}
