*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-light: #818cf8;--primary-dark: #4f46e5;--bg: #f8fafc;--bg-card: #ffffff;--text: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--hot: #ef4444;--new: #10b981;--radius: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}a{text-decoration:none;color:inherit}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.logo{font-size:20px;font-weight:700;color:var(--primary)}.nav{display:flex;align-items:center;gap:20px}.nav a{font-size:14px;color:var(--text-secondary);transition:color .2s}.nav a:hover{color:var(--primary)}.btn-create{background:var(--primary);color:#fff!important;padding:8px 16px;border-radius:8px;font-weight:600;font-size:14px;transition:background .2s}.btn-create:hover{background:var(--primary-dark)}.main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:24px 16px}.footer{text-align:center;padding:24px;color:var(--text-secondary);font-size:13px;border-top:1px solid var(--border)}.home-header{text-align:center;margin-bottom:24px}.home-header h1{font-size:28px;margin-bottom:4px}.subtitle{color:var(--text-secondary);font-size:14px}.category-bar{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px;margin-bottom:16px;-webkit-overflow-scrolling:touch}.cat-btn{padding:6px 14px;border:1px solid var(--border);background:var(--bg-card);border-radius:20px;font-size:13px;cursor:pointer;white-space:nowrap;transition:all .2s}.cat-btn:hover,.cat-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.section-labels{display:flex;gap:12px;margin-bottom:12px}.section-labels .label{font-size:13px;font-weight:600;padding:4px 10px;border-radius:6px}.section-labels .label.hot{background:#fef2f2;color:var(--hot)}.section-labels .label.new{background:#ecfdf5;color:var(--new)}.topic-grid{display:flex;flex-direction:column;gap:12px}.topic-item{position:relative}.badge{position:absolute;top:-6px;left:12px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;z-index:1}.badge.hot{background:var(--hot);color:#fff}.badge.new{background:var(--new);color:#fff}.divider{text-align:center;color:var(--text-secondary);font-size:13px;padding:12px 0 4px;border-top:1px dashed var(--border);margin:8px 0}.topic-card{display:block;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .2s;cursor:pointer}.topic-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-light);transform:translateY(-1px)}.topic-card.compact{padding:12px}.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card-cat{font-size:12px;color:var(--primary);background:#eef2ff;padding:2px 8px;border-radius:4px}.card-time{font-size:12px;color:var(--text-secondary)}.card-title{font-size:16px;font-weight:600;margin-bottom:6px;line-height:1.4}.card-desc{font-size:13px;color:var(--text-secondary);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-secondary)}.card-votes{font-weight:600;color:var(--primary)}.create-page h1{text-align:center;margin-bottom:24px}.create-form{max-width:560px;margin:0 auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:border-color .2s;outline:none;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary)}.char-count{float:right;font-size:12px;color:var(--text-secondary);margin-top:4px}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.vote-type-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden}.vote-type-toggle button{flex:1;padding:10px;border:none;background:var(--bg);cursor:pointer;font-size:14px;transition:all .2s}.vote-type-toggle button.active{background:var(--primary);color:#fff}.option-row{display:flex;gap:8px;margin-bottom:8px}.option-row input{flex:1}.btn-remove{width:36px;height:36px;border:1px solid var(--border);background:var(--bg);border-radius:8px;cursor:pointer;font-size:14px;color:var(--text-secondary);transition:all .2s;flex-shrink:0}.btn-remove:hover{background:#fef2f2;color:var(--hot);border-color:var(--hot)}.btn-add-option{width:100%;padding:10px;border:1px dashed var(--border);background:var(--bg);border-radius:8px;cursor:pointer;font-size:14px;color:var(--primary);transition:all .2s}.btn-add-option:hover{border-color:var(--primary);background:#eef2ff}.btn-submit{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.btn-submit:hover:not(:disabled){background:var(--primary-dark)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.detail-page{max-width:640px;margin:0 auto}.detail-header{margin-bottom:24px}.cat-tag{display:inline-block;font-size:12px;color:var(--primary);background:#eef2ff;padding:2px 10px;border-radius:4px;margin-bottom:8px}.detail-header h1{font-size:24px;margin-bottom:8px}.detail-header .desc{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.meta{display:flex;gap:16px;font-size:13px;color:var(--text-secondary)}.options-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.option-item{position:relative;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;overflow:hidden;transition:all .2s}.option-item:hover:not(.voted){border-color:var(--primary-light)}.option-item.selected{border-color:var(--primary);background:#eef2ff}.option-item.voted{cursor:default}.option-item.my-vote{border-color:var(--primary);background:#eef2ff}.option-item.winner{border-color:var(--new)}.option-bar{position:absolute;left:0;top:0;bottom:0;background:#e0e7ff;transition:width .8s ease-out;z-index:0;min-width:0}.option-item:not(.voted) .option-bar{background:#f1f5f9}.option-item.winner .option-bar{background:#d1fae5}.option-content{position:relative;z-index:1;display:flex;align-items:center;gap:10px}.option-check{font-size:16px;flex-shrink:0}.option-text{flex:1;font-size:15px}.option-stats{display:flex;gap:8px;font-size:13px;color:var(--text-secondary)}.option-stats .percent{font-weight:700;color:var(--primary)}.btn-vote{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.btn-vote:hover:not(:disabled){background:var(--primary-dark)}.btn-vote:disabled{opacity:.5;cursor:not-allowed}.voted-msg{text-align:center;color:var(--new);font-weight:600;padding:16px;font-size:15px}.ranking-page h1{text-align:center;margin-bottom:20px}.rank-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:20px}.rank-tabs button{padding:8px 20px;border:1px solid var(--border);background:var(--bg-card);border-radius:20px;cursor:pointer;font-size:14px;transition:all .2s}.rank-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.rank-list{display:flex;flex-direction:column;gap:10px}.rank-item{display:flex;align-items:center;gap:12px}.rank-num{width:40px;text-align:center;font-size:14px;font-weight:700;color:var(--text-secondary);flex-shrink:0}.rank-num.top{font-size:24px}.rank-item .topic-card{flex:1}.loading,.empty,.error-page,.no-more{text-align:center;padding:40px;color:var(--text-secondary);font-size:14px}.load-more{display:block;margin:20px auto;padding:10px 32px;border:1px solid var(--border);background:var(--bg-card);border-radius:20px;cursor:pointer;font-size:14px;transition:all .2s}.load-more:hover{border-color:var(--primary);color:var(--primary)}.error-msg{background:#fef2f2;color:var(--hot);padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:16px}.owner-actions{display:flex;gap:8px;margin-top:12px}.btn-action{padding:6px 14px;border:1px solid var(--border);background:var(--bg-card);border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s}.btn-action.btn-edit:hover{border-color:var(--primary);color:var(--primary);background:#eef2ff}.btn-action.btn-delete:hover{border-color:var(--hot);color:var(--hot);background:#fef2f2}.action-expired{font-size:12px;color:var(--text-secondary);padding:6px 0}.edit-form{margin:8px 0}.edit-title-input{width:100%;padding:10px 12px;border:2px solid var(--primary);border-radius:8px;font-size:20px;font-weight:600;outline:none;margin-bottom:8px}.edit-desc-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;outline:none;resize:vertical;font-family:inherit;margin-bottom:8px}.edit-desc-input:focus{border-color:var(--primary)}.edit-actions{display:flex;gap:8px}.btn-edit-save{padding:8px 20px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.btn-edit-cancel{padding:8px 20px;background:var(--bg);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f1f5f9}.admin-login-box{background:var(--bg-card);border-radius:var(--radius);padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-md)}.admin-login-box h1{text-align:center;margin-bottom:24px}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:220px;background:#1e293b;color:#e2e8f0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.admin-logo{padding:20px;font-size:18px;font-weight:700;border-bottom:1px solid #334155}.admin-nav{flex:1;padding:12px 0}.admin-nav-item{display:block;padding:10px 20px;color:#94a3b8;font-size:14px;transition:all .2s}.admin-nav-item:hover{background:#334155;color:#fff}.admin-nav-item.active{background:#334155;color:#fff;border-left:3px solid var(--primary)}.admin-footer{padding:16px 20px;border-top:1px solid #334155;display:flex;justify-content:space-between;align-items:center;font-size:13px}.btn-logout{background:transparent;border:1px solid #475569;color:#94a3b8;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px}.btn-logout:hover{background:#475569;color:#fff}.admin-main{flex:1;margin-left:220px;padding:24px;background:#f8fafc;min-height:100vh}.admin-page h1{margin-bottom:20px;font-size:22px}.admin-loading{text-align:center;padding:40px;color:var(--text-secondary)}.admin-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.admin-search{padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;outline:none;min-width:200px}.admin-search:focus{border-color:var(--primary)}.admin-search.small{min-width:120px}.admin-select{padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;outline:none;background:#fff}.admin-count{margin-left:auto;font-size:13px;color:var(--text-secondary)}.btn-admin{padding:8px 16px;border:1px solid var(--border);background:#fff;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.btn-admin:hover{border-color:var(--primary);color:var(--primary)}.btn-admin.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-admin.btn-primary:hover{background:var(--primary-dark)}.btn-admin.btn-danger{background:var(--hot);color:#fff;border-color:var(--hot)}.btn-admin.btn-warn{background:#f59e0b;color:#fff;border-color:#f59e0b}.btn-admin.btn-success{background:var(--new);color:#fff;border-color:var(--new)}.batch-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#eef2ff;border-radius:6px;margin-bottom:12px;font-size:14px}.batch-bar span{margin-right:8px}.admin-table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.admin-table th{background:#f1f5f9;padding:10px 12px;text-align:left;font-size:13px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:10px 12px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:hover{background:#f8fafc}.admin-table tr.row-disabled{opacity:.6}.td-title{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-ip{font-family:monospace;font-size:12px}.td-fp{font-family:monospace;font-size:12px;color:var(--text-secondary)}.td-icon{font-size:20px}.td-actions{white-space:nowrap;display:flex;gap:4px}.btn-sm{padding:4px 10px;border:1px solid var(--border);background:#fff;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.btn-sm.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-sm.btn-danger{background:var(--hot);color:#fff;border-color:var(--hot)}.btn-sm.btn-warn{background:#f59e0b;color:#fff;border-color:#f59e0b}.btn-sm.btn-success{background:var(--new);color:#fff;border-color:var(--new)}.status-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600}.status-tag.active{background:#dcfce7;color:#166534}.status-tag.disabled{background:#fee2e2;color:#991b1b}.flag-tag{font-size:12px}.empty-hint{text-align:center;color:var(--text-secondary);padding:20px}.admin-pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:16px}.admin-pagination button{padding:6px 16px;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer}.admin-pagination button:disabled{opacity:.5;cursor:not-allowed}.admin-tabs{display:flex;gap:8px;margin-bottom:16px}.admin-tabs button{padding:8px 20px;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer;font-size:14px}.admin-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.admin-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.admin-card h3{margin-bottom:12px;font-size:15px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}.stat-card.accent{border-color:var(--primary);background:#eef2ff}.stat-value{font-size:28px;font-weight:700;color:var(--primary);margin-bottom:4px}.stat-label{font-size:13px;color:var(--text-secondary)}.dashboard-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.dashboard-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.dashboard-card h3{margin-bottom:16px;font-size:15px}.mini-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:8px}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.chart-bar{width:100%;max-width:40px;background:var(--primary);border-radius:4px 4px 0 0;min-height:4px;transition:height .3s}.chart-bar.vote{background:var(--new)}.chart-label{font-size:11px;color:var(--text-secondary);margin-top:4px}.export-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.export-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.export-card h3{margin-bottom:8px}.export-card p{color:var(--text-secondary);font-size:14px;margin-bottom:16px}.export-actions{display:flex;gap:8px}@media (max-width: 768px){.admin-sidebar{width:60px}.admin-logo{font-size:14px;padding:16px 8px;text-align:center}.admin-nav-item{padding:10px 8px;text-align:center;font-size:16px}.admin-footer{flex-direction:column;gap:8px;padding:12px 8px}.admin-main{margin-left:60px;padding:16px}.dashboard-row,.export-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.header{padding:0 16px}.nav{gap:12px}.nav a:not(.btn-create){font-size:13px}.main{padding:16px 12px}.home-header h1{font-size:22px}.detail-header h1{font-size:20px}.form-row{flex-direction:column;gap:0}.meta{flex-wrap:wrap;gap:8px}}
