body{margin:0;font-family:Arial,sans-serif;background:#f9f9f9;color:#333}#app{display:flex;flex-direction:column;min-height:100vh}main{flex:1;padding:1rem}header{background:#1f74b6;color:#fff;padding:1rem;display:flex;flex-direction:column;gap:.75rem;position:sticky;top:0;z-index:10}.header-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.header-top h1{margin:0}.header-bottom{display:flex;justify-content:space-between;align-items:center}#controls form{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}#controls input[type=text],#controls select,#controls button{height:2.25rem;padding:.25rem .5rem;border:none;border-radius:4px;box-sizing:border-box}#favorites-bar{margin:.5rem 0 0 1rem}#favorites-bar ul{list-style:none;padding:0;margin:.5rem 0 0}#favorites-bar li{margin-bottom:.25rem}#favorites-bar button{margin-left:.5rem}button{background:#fff;color:#1f74b6;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:700;box-shadow:0 2px 4px #0003;white-space:nowrap}button:hover{background:#f0f0f0}table{width:100%;border-collapse:collapse;margin-top:1rem;background:#fff;box-shadow:0 2px 6px #0000001a}thead{background:#eaeaea;position:sticky;top:0;z-index:2}th,td{padding:.75rem;border-bottom:1px solid #ddd;text-align:left}tbody tr:nth-child(2n){background:#f6f6f6}tbody tr:hover{background:#dceeff}body.dark{background:#121212;color:#eaeaea}body.dark table{background:#1e1e1e;color:#eaeaea}body.dark thead{background:#2a2a2a;position:sticky;top:0;z-index:2}body.dark th,body.dark td{border-bottom:1px solid #333}body.dark tbody tr:nth-child(2n){background:#1a1a1a}body.dark tbody tr:hover{background:#2f4f6f}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{text-decoration:underline}.arrow{cursor:pointer;margin-left:.25rem;font-size:.9em;color:#555}.arrow:hover{color:#000}body.dark .arrow{color:#fff}body.dark .arrow:hover{color:#ccc}td.numeric,th.numeric{text-align:right}
