table.personal th {
font-size:20px;
}
table.personal td, th {
/* Behave like a "row" */
border: none;
border-bottom: 1px solid #eee;
position: relative;
padding: 15px;
}
/*
Max width before this PARTICULAR table gets nasty. This query will take effect for any screen smaller than 760px and also iPads specifically.
*/
@media
only screen
and (max-width: 1000px), (min-device-width: 1008px)
and (max-device-width: 1024px) {
/* Force table to not be like tables anymore */
table, thead, tbody, th, td, tr {
display: block;
}
table.personal {
width:100%;
}
/* Hide table headers (but not display: none;, for accessibility) */
table.personal tr.thead {
position: absolute;
top: -9999px;
left: -9999px;
}
table.personal tr {
margin: 0 0 1rem 0;
}
table.personal tr:nth-child(odd) {
background: #ccc;
}
table.personal td {
/* Behave like a "row" */
border: none;
border-bottom: 1px solid #eee;
position: relative;
padding-left: 25%;
}
table.personal td:before {
/* Now like a table header */
position: absolute;
/* Top/left values mimic padding */
top: 0;
left: 6px;
width: 20%;
padding-right: 10px;
white-space: nowrap;
}
/*
Label the data
You could also use a data-* attribute and content for this. That way "bloats" the HTML, this way means you need to keep HTML and CSS in sync. Lea Verou has a clever way to handle with text-shadow.
*/
table.personal td:nth-of-type(1):before { content: "Nº"; }
table.personal td:nth-of-type(2):before { content: "EDITOR"; }
table.personal td:nth-of-type(3):before { content: "FIXED"; }
table.personal td:nth-of-type(4):before { content: "SEEMSOK"; }
table.personal td:nth-of-type(5):before { content: "NOTENOUGHT"; }
table.personal td:nth-of-type(6):before { content: "SPLIT R"; }
table.personal td:nth-of-type(7):before { content: "POINTS"; }
}