*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#1a1a1a}.app{max-width:900px;margin:0 auto;padding:0 16px}.app-header{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:2px solid #e0e0e0;margin-bottom:16px;position:sticky;top:0;background:#f5f5f5;z-index:10}.app-header h1{font-size:1.4rem;font-weight:700}.subtitle{font-size:.85rem;color:#666;margin-left:8px}.header-right{display:flex;align-items:center;gap:12px;font-size:.85rem;color:#666}.mark-read-btn{border:1px solid #ccc;background:#fff;padding:3px 10px;border-radius:6px;font-size:.8rem;cursor:pointer;color:#555;font-weight:600}.mark-read-btn:hover{background:#e8e8e8;border-color:#999}.stat-stored{color:#999;background:transparent}.poll-status.loading{color:#e67e22}.stat{background:#e8e8e8;padding:2px 8px;border-radius:10px}.listing-list{display:flex;flex-direction:column;gap:8px;padding-bottom:32px}.listing-card{display:flex;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014;transition:box-shadow .15s}.listing-card:hover{box-shadow:0 2px 8px #0000001f}.listing-card.is-new{border-left:3px solid #27ae60}.listing-card.is-upvoted{background:#f0faf0}.card-image-link{flex-shrink:0}.card-image{width:120px;height:90px;object-fit:cover;display:block}.card-no-image{display:flex;align-items:center;justify-content:center;background:#eee;color:#999;font-size:.75rem}.card-body{flex:1;padding:8px 12px;min-width:0;display:flex;flex-direction:column;gap:4px}.card-top-row{display:flex;align-items:center;gap:8px}.category-badge{background:#3498db;color:#fff;font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}.cat-parent{opacity:.8}.cat-sep{opacity:.5;margin:0 1px}.cat-child{font-weight:700}.new-badge{background:#27ae60;color:#fff;font-size:.65rem;padding:1px 6px;border-radius:8px;font-weight:700}.card-heading{font-size:.9rem;font-weight:600;color:#1a1a1a;text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-heading:hover{color:#3498db}.card-meta{display:flex;gap:12px;font-size:.75rem;color:#888}.meta-drive{color:#e67e22;font-weight:600}.vote-buttons{display:inline-flex;align-items:center;gap:2px}.vote-group{display:inline-flex;align-items:center;gap:1px}.vote-sep{color:#ccc;font-size:.75rem;margin:0 2px}.vote-effective{font-size:.7rem;font-weight:700;margin-left:3px;color:#888}.vote-effective.positive{color:#27ae60}.vote-effective.negative{color:#e74c3c}.vote-btn{border:none;background:#eee;width:22px;height:22px;border-radius:4px;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#555}.vote-btn:hover{background:#ddd}.vote-up:hover{background:#d5f5e3;color:#27ae60}.vote-down:hover{background:#fadbd8;color:#e74c3c}.vote-score{font-size:.75rem;font-weight:700;min-width:20px;text-align:center}.vote-score.positive{color:#27ae60}.vote-score.negative{color:#e74c3c}.hidden-items{margin:4px 0}.hidden-toggle{border:1px dashed #ccc;background:transparent;padding:6px 12px;width:100%;text-align:left;cursor:pointer;border-radius:6px;font-size:.8rem;color:#999}.hidden-toggle:hover{border-color:#999;color:#666}.hidden-list{display:flex;flex-direction:column;gap:4px;margin-top:4px;opacity:.7}.loading-msg{text-align:center;padding:48px;color:#999;font-size:1.1rem}
