*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:#f5f5f5;padding:10px;margin:0;}
.container{display:flex;flex-direction:column;gap:16px;}
h1{display:none;}
.controls{background:white;padding:8px 20px;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,0.1);margin-bottom:15px;line-height:1.2;}
.search-box{width:100%;padding:3px 28px 3px 8px;font-size:18px;border:none;border-radius:0;height:28px;line-height:22px;outline:none;background:transparent;}
.search-box:focus{outline:none;}
.search-clear-button{position:absolute;right:4px;top:50%;transform:translateY(-50%);border:none;background:rgba(0,0,0,0.12);color:#555;width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1;transition:background 0.2s;}
.search-clear-button:hover{background:rgba(0,0,0,0.2);}
.search-clear-button:active{background:rgba(0,0,0,0.3);}
/* 搜索历史下拉列表 */
.search-history-dropdown{position:absolute;top:100%;left:0;right:0;background:#ffffff !important;border:1px solid #ddd;border-top:none;border-radius:0 0 4px 4px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px rgba(0,0,0,0.1);margin-top:0;}
.search-history-item{padding:8px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f0f0f0;font-size:14px;background:#ffffff;}
.search-history-item:hover{background:#f5f5f5;}
.search-history-item:last-child{border-bottom:none;}
.search-history-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.search-history-delete{padding:0;background:transparent;color:#999;border:none;border-radius:3px;cursor:pointer;font-size:18px;margin-left:8px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;line-height:1;}
.search-history-delete:hover{color:#f44336;background:#f5f5f5;}
.search-history-empty{padding:12px;text-align:center;color:#999;font-size:13px;}
.controls input[type="range"]#dafontThreshold{margin:0;padding:0;-webkit-appearance:none;appearance:none;}
.controls input[type="range"]#dafontThreshold::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;}
.filters{display:flex;gap:15px;flex-wrap:wrap;}
.filter-group{flex:1;min-width:200px;}
.filter-group label{display:block;margin-bottom:5px;color:#666;font-size:16px;}
.filter-group select{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;}
.fonts-table{width:100%;border-collapse:collapse;background:white;font-size:13px;line-height:1.1;}
.fonts-table thead th{background:#f0f0f0;padding:3px 8px;text-align:left;font-weight:bold;border-bottom:2px solid #ddd;cursor:pointer;user-select:none;}
.fonts-table thead th:hover{background:#e0e0e0;}
.fonts-table thead th.sort-asc::after{content:" ↑";color:#2196F3;}
.fonts-table thead th.sort-desc::after{content:" ↓";color:#2196F3;}
.fonts-table tbody tr:nth-child(even){background:#f9f9f9;}
.fonts-table tbody tr:hover{background:#f0f8ff;}
.fonts-table tbody tr.row-highlighted{background:#fff7e6 !important;box-shadow:inset 0 0 0 1px #ffbb55;}
.fonts-table tbody tr.comment-focus{background:#ffe6e6 !important;box-shadow:inset 0 0 0 1px #ff6666;}
.fonts-table td{padding:3px 8px;border-bottom:1px solid #eee;vertical-align:middle;line-height:1.2;height:40px;}
.font-row-hover{background:#fffde7 !important;}
.font-row-highlight{background:#ffe082 !important;}
.font-name-link{color:#2196F3;text-decoration:none;font-weight:bold;font-size:13px;}
.font-name-link:hover{text-decoration:underline;color:#1976D2;}
.font-preview{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;cursor:pointer;position:relative;}
.font-author-cell{color:#555;font-size:12px;}
.icon-toggle{cursor:pointer;transition:transform 0.2s ease;user-select:none;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;line-height:1;}
.icon-toggle:hover{transform:scale(1.12);}
.icon-toggle-img{width:20px;height:20px;display:block;}
.favorite-icon .icon-toggle-img{filter:none;}
.favorite-icon.active .icon-toggle-img{filter:none;}
.dislike-icon .icon-toggle-img{filter:none;}
.dislike-icon.active .icon-toggle-img{filter:none;}
/* 对话框中的图标在深色背景下显示更明显的颜色 */
.image-modal .icon-toggle{filter:brightness(0.9);}
.image-modal .icon-toggle:hover{transform:scale(1.12);}
/* Test对话框中的图标 */
.font-modal .icon-toggle{filter:brightness(0.95);}
.font-modal .icon-toggle:hover{transform:scale(1.12);}
.action-buttons{display:flex;gap:5px;align-items:center;justify-content:flex-start;}
.action-btn{padding:4px 8px;font-size:12px;border:1px solid #ddd;border-radius:4px;background:white;color:#333;cursor:pointer;transition:all 0.2s;text-decoration:none;display:inline-block;}
.action-btn:hover{background:#f0f0f0;border-color:#999;}
.action-btn.view{background:#3498db;color:white;border-color:#3498db;}
.action-btn.view:hover{background:#2980b9;border-color:#2980b9;}
.action-btn.test{background:#2ecc71;color:white;border-color:#2ecc71;}
.action-btn.test:hover{background:#27ae60;border-color:#27ae60;}
/* 大图预览容器 */
.preview-container{position:relative;display:block;cursor:pointer;width:100%;}
.preview-zoom{position:fixed;z-index:10000;background:white;border:2px solid #2196F3;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,0.3);padding:8px;display:none;pointer-events:none;overflow:visible;}
.preview-zoom img{max-width:none;max-height:none;width:auto;height:auto;display:block;}
.preview-container:hover .preview-zoom{display:block;}
/* 确保表格单元格允许overflow */
.fonts-table td{overflow:visible;}
/* 大图查看模态框 */
.image-modal{display:none;position:fixed;z-index:20000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,0.9);overflow:auto;}
.image-modal.active{display:flex;flex-direction:column;align-items:center;justify-content:center;}
.image-modal-content{position:relative;max-width:95%;max-height:95%;margin:20px;background:white;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,0.5);overflow:auto;}
.image-modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #ddd;background:#f5f5f5;border-radius:8px 8px 0 0;}
.image-modal-title{font-size:15px;font-weight:bold;color:#333;}
.image-modal-controls{display:flex;gap:10px;align-items:center;}
.image-modal-btn{padding:6px 12px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;font-size:13px;transition:all 0.2s;}
.image-modal-btn:hover{background:#f0f0f0;border-color:#2196F3;}
.image-modal-btn:active{background:#e0e0e0;}
.image-modal-close{padding:6px 12px;border:1px solid #ddd;background:#f44336;color:white;border-radius:4px;cursor:pointer;font-size:13px;font-weight:bold;}
.image-modal-close:hover{background:#d32f2f;}
.image-modal-body{padding:10px;text-align:center;overflow:auto;min-height:100px;}
.image-modal-body img{display:block;margin:0 auto;transition:transform 0.3s ease;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;}
.zoom-info{margin-left:10px;color:#666;font-size:13px;min-width:60px;text-align:right;}
/* 字体对话框样式 */
.font-modal{display:none;position:fixed;z-index:20001;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,0.7);overflow:auto;}
.font-modal.active{display:flex;align-items:center;justify-content:center;}
.font-modal-content{position:relative;max-width:600px;max-height:90%;margin:20px;background:white;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,0.5);overflow:auto;}
.font-modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #ddd;background:#f5f5f5;border-radius:8px 8px 0 0;}
.font-modal-title{font-size:15px;font-weight:bold;color:#333;}
.font-modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:30px;height:30px;line-height:30px;text-align:center;}
.font-modal-close:hover{color:#333;background:#e0e0e0;border-radius:4px;}
.font-modal-body{padding:20px;}
.font-info-item{margin-bottom:10px;font-size:13px;}
.font-info-label{font-weight:bold;color:#666;display:inline-block;width:120px;}
.font-info-value{color:#333;}
.btn{padding:4px 8px;border:none;border-radius:2px;cursor:pointer;font-size:13px;transition:background 0.2s;text-decoration:none;text-align:center;display:inline-block;font-weight:600;}
.btn-primary{background:#2196F3;color:white;}
.btn-primary:hover{background:#1976D2;}
.btn-secondary{background:#f5f5f5;color:#333;border:1px solid #ddd;}
.btn-secondary:hover{background:#e0e0e0;}
.test-font-btn{background:#4CAF50;color:white;}
.test-font-btn:hover{background:#45a049;}
.loading{text-align:center;padding:40px;color:#999;}
.error{background:#ffebee;color:#c62828;padding:15px;border-radius:4px;margin-bottom:20px;}
.pagination{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:30px;flex-wrap:wrap;}
.pagination button,.pagination .page-btn{display:inline-flex;align-items:center;justify-content:center;width:auto !important;min-width:36px;padding:8px 16px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;}
.pagination .page-btn{padding:8px 16px;}
.pagination .page-btn.active{background:#2196F3;color:white;border-color:#2196F3;}
.pagination .page-btn:hover:not(.active){background:#f5f5f5;}
@keyframes spin {
0%{transform:rotate(0deg);}
100%{transform:rotate(360deg);}
}
/* 搜索loading动画 */
.search-loading{display:inline-block;width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-left:8px;vertical-align:middle;}
.comment-item{padding:15px;margin-bottom:15px;border:1px solid #ddd;border-radius:4px;background:#f9f9f9;}
.comment-author{font-weight:bold;color:#333;margin-bottom:5px;font-size:13px;}
.comment-date{color:#666;font-size:11px;margin-bottom:8px;}
.comment-text{color:#333;font-size:13px;line-height:1.5;word-wrap:break-word;}
.comment-text img{max-width:100%;height:auto;}
.comment-text a{color:#2196F3;text-decoration:none;}
.comment-text a:hover{text-decoration:underline;}
.fonts-table th.screenshot-col,.fonts-table td.screenshot-cell{min-width:320px;width:33%;}
.fonts-table td.screenshot-cell{vertical-align:top;}
.fonts-table.hide-author th.col-author,.fonts-table.hide-author td.col-author{display:none;}
.fonts-table.hide-total-downloads th.col-total-downloads,.fonts-table.hide-total-downloads td.col-total-downloads{display:none;}
.fonts-table.hide-yesterday-downloads th.col-yesterday-downloads,.fonts-table.hide-yesterday-downloads td.col-yesterday-downloads{display:none;}