*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}body{margin:0;padding:0;min-height:100vh;color:#111827;background-color:#f8fafc}#root{min-height:100vh}button{border:none;background:none;cursor:pointer;font-family:inherit;transition:all .2s ease}input{font-family:inherit;border:none;outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f3f4f6}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media print{.app-header{background:#fff!important;box-shadow:none!important;border-bottom:1px solid #000!important}.action-btn{display:none!important}.challenge-grid{background:#fff!important;box-shadow:none!important;border:1px solid #000!important}.challenge-card{background:#fff!important;box-shadow:none!important;border:1px solid #000!important;break-inside:avoid}.edit-btn{display:none!important}}.challenge-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;transition:all .2s ease;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;height:100%;min-height:200px}.challenge-card:hover{border-color:#3b82f6;box-shadow:0 4px 8px #0000001a}.challenge-card.has-content{border-left:3px solid #10b981}.challenge-card.empty{border-left:3px solid #d1d5db}.card-header{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.day-number{font-size:12px;font-weight:600;color:#374151;background:#e5e7eb;padding:4px 8px;border-radius:4px}.edit-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.edit-btn:hover{background:#e5e7eb;color:#374151}.card-content{flex:1;padding:12px;display:flex;flex-direction:column;gap:8px}.song-cover{width:100%;height:80px;border-radius:4px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.song-cover img{width:100%;height:100%;object-fit:cover}.default-cover{display:flex;align-items:center;justify-content:center;color:#9ca3af}.song-info{flex:1;display:flex;flex-direction:column;gap:4px}.song-title{font-size:13px;font-weight:600;color:#111827;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.song-artist{font-size:12px;color:#6b7280;font-weight:500;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.song-album{font-size:11px;color:#9ca3af;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.song-count{font-size:10px;color:#6b7280;background:#f3f4f6;padding:2px 6px;border-radius:10px;align-self:flex-start;font-weight:500}.empty-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:120px;color:#9ca3af;text-align:center}.empty-icon{opacity:.5}.add-song-text{font-size:12px;font-weight:500}.card-footer{padding:8px 12px;border-top:1px solid #f3f4f6;background:#f9fafb}.challenge-title{font-size:11px;font-weight:600;color:#111827;margin-bottom:2px;line-height:1.3}.challenge-description{font-size:10px;color:#6b7280;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media (max-width: 768px){.challenge-card{min-height:180px}.song-cover{height:60px}.card-header,.card-content,.card-footer{padding:8px}}.challenge-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(6,1fr);gap:16px;padding:24px;background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000014;max-width:1200px;margin:0 auto}@media (max-width: 1024px){.challenge-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(10,1fr);gap:12px;padding:16px}}@media (max-width: 768px){.challenge-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(15,1fr);gap:8px;padding:12px}}@media (max-width: 480px){.challenge-grid{grid-template-columns:1fr;grid-template-rows:repeat(30,1fr);gap:8px;padding:12px}}.export-card{aspect-ratio:1;border-radius:8px;overflow:hidden;position:relative;background:#f9fafb;border:1px solid #e5e7eb}.export-card.has-cover{background:#000;border:none}.export-card.empty{background:#f9fafb;border:1px solid #e5e7eb}.export-card-overlay{position:absolute;inset:0;padding:14px 14px 10px;display:flex;flex-direction:column;justify-content:space-between}.export-top-info{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.export-card.has-cover .export-card-overlay{background:none;color:#fff}.export-card.empty .export-card-overlay,.export-card:not(.has-cover) .export-card-overlay{color:#111827;background:none}.export-day-number{font-size:11px;font-weight:700;background:#ffffffe6;color:#1f2937;padding:5px 10px;border-radius:12px;align-self:flex-start;letter-spacing:.3px}.export-day-title{font-size:11px;font-weight:700;background:#ffffffe6;color:#1f2937;padding:5px 10px;border-radius:12px;align-self:flex-start;letter-spacing:.3px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.export-card.has-cover .export-day-number,.export-card.has-cover .export-day-title{background:#ffffffe6;color:#1f2937}.export-song-count{font-size:10px;font-weight:600;background:#ffffffe6;color:#6b7280;padding:3px 8px;border-radius:10px;align-self:flex-start;margin-bottom:4px}.export-card.has-cover .export-song-count{background:#ffffffe6;color:#6b7280}.export-song-info{display:flex;flex-direction:column;justify-content:flex-end;text-align:left;padding:0}.export-song-title{font-size:24px;font-weight:700;line-height:1.1;margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.export-card.has-cover .export-song-title{color:#fff}.export-song-meta{display:flex;align-items:center;margin-bottom:0;overflow:hidden;white-space:nowrap}.export-song-artist{font-size:16px;font-weight:600;color:inherit;flex-shrink:0}.export-meta-separator{font-size:16px;font-weight:400;color:inherit;opacity:.7;flex-shrink:0}.export-card.has-cover .export-song-artist{color:#fffffff2}.export-card.has-cover .export-meta-separator{color:#ffffffb3}.export-card:not(.has-cover) .export-song-artist{color:#6b7280}.export-card:not(.has-cover) .export-meta-separator{color:#9ca3af}.export-song-album{font-size:16px;font-weight:400;color:inherit;opacity:.8;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;min-width:0}.export-card.has-cover .export-song-album{color:#fffc}.export-card:not(.has-cover) .export-song-album{color:#9ca3af}.export-empty-content{flex:1;display:flex;flex-direction:column;justify-content:center;text-align:center;padding:4px 0}.export-challenge-title{font-size:24px;font-weight:700;line-height:1.1;margin-bottom:6px;color:#111827;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.export-challenge-desc{font-size:13px;font-weight:400;line-height:1.4;color:#6b7280;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.export-challenge-hint{font-size:10px;font-weight:600;text-align:left;background:#ffffffe6;color:#6b7280;padding:4px 8px;border-radius:8px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.export-card.has-cover .export-challenge-hint{background:#ffffffe6;color:#6b7280}.export-grid{background:#fff;padding:48px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,sans-serif;width:1200px;margin:0 auto;min-height:auto}.export-header{text-align:center;margin-bottom:36px;color:#111827}.export-title{font-size:32px;font-weight:600;margin:0;letter-spacing:-.5px;color:#111827}.export-cards{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(6,1fr);gap:8px;margin-bottom:32px}.export-footer{text-align:center;color:#9ca3af}.export-watermark{font-size:12px;font-weight:500;letter-spacing:.5px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:480px;width:100%;max-height:90vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.modal-title{display:flex;align-items:center;gap:8px;margin:0;font-size:18px;font-weight:600;color:#111827}.close-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#e5e7eb;color:#374151}.modal-body{padding:24px;max-height:calc(90vh - 140px);overflow-y:auto}.challenge-info{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:16px;margin-bottom:20px}.challenge-theme{font-size:14px;font-weight:600;color:#111827;margin-bottom:4px}.challenge-desc{font-size:13px;color:#6b7280;line-height:1.5}.song-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:#374151}.form-group input{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:all .2s ease;background:#fff}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.cover-preview{margin-top:8px;display:flex;justify-content:center}.cover-preview img{max-width:100px;max-height:100px;border-radius:6px;object-fit:cover;border:1px solid #e5e7eb}.modal-actions{display:flex;gap:8px;margin-top:20px;justify-content:flex-end}.save-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.save-btn:hover{background:#059669}.cancel-btn{padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background:#f9fafb;border-color:#9ca3af}.songs-section{margin-bottom:16px}.songs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.songs-header h4{margin:0;font-size:16px;font-weight:600;color:#111827}.add-song-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-song-btn:hover{background:#2563eb}.song-item{border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:16px;background:#fff;transition:all .2s ease}.song-item:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000d}.song-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f3f4f6}.song-number-section{display:flex;align-items:center;gap:8px}.drag-handle{color:#9ca3af;cursor:grab;transition:color .2s ease}.drag-handle:hover{color:#6b7280}.drag-handle:active{cursor:grabbing}.song-number{font-size:14px;font-weight:600;color:#6b7280}.primary-tag{background:#10b981;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-weight:500}.song-controls{display:flex;align-items:center;gap:4px}.move-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.move-btn:hover:not(:disabled){background:#f3f4f6;color:#374151}.move-btn:disabled{opacity:.4;cursor:not-allowed}.remove-song-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.remove-song-btn:hover{background:#fef2f2;color:#dc2626}.song-fields{display:flex;flex-direction:column;gap:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 768px){.modal{margin:16px;max-width:none}.modal-header{padding:16px 20px}.modal-title{font-size:16px}.modal-body{padding:20px}.modal-actions{flex-direction:column-reverse}.save-btn,.cancel-btn{width:100%;justify-content:center}.form-row{grid-template-columns:1fr}.songs-header,.song-header{flex-direction:column;align-items:stretch;gap:8px}.song-number-section,.song-controls{justify-content:center}}.app{min-height:100vh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.app-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#fff;border-bottom:1px solid #e5e7eb}.app-title{display:flex;align-items:center;gap:8px;margin:0;font-size:20px;font-weight:600;color:#111827}.title-icon{color:#3b82f6}.app-actions{display:flex;gap:8px}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#fff;color:#374151}.action-btn:hover{border-color:#9ca3af;background:#f9fafb}.preview-btn{background:#3b82f6;color:#fff;border-color:#3b82f6}.preview-btn:hover{background:#2563eb;border-color:#2563eb}.export-btn{background:#10b981;color:#fff;border-color:#10b981}.export-btn:hover{background:#059669;border-color:#059669}.reset-btn{background:#ef4444;color:#fff;border-color:#ef4444}.reset-btn:hover{background:#dc2626;border-color:#dc2626}.critique-btn{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.critique-btn:hover:not(:disabled){background:#7c3aed;border-color:#7c3aed}.critique-btn:disabled{background:#d1d5db;color:#9ca3af;border-color:#d1d5db;cursor:not-allowed}.app-main{padding:24px;max-width:1400px;margin:0 auto}.preview-container{min-height:100vh;background:#f3f4f6;padding:20px}.preview-header{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto 30px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.preview-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.preview-actions{display:flex;gap:12px}.preview-content{display:flex;justify-content:center;align-items:flex-start;min-height:calc(100vh - 120px)}@media (max-width: 768px){.app-header{flex-direction:column;gap:16px;padding:16px}.app-title{font-size:18px}.app-main{padding:16px}.action-btn{padding:8px 12px;font-size:13px}}
