.project-meta-editor input.project-title-input{width:100%;font-size:2rem;font-weight:700;border-bottom:2px solid #ccc;margin-bottom:.5rem;padding:.25rem .5rem}.project-meta-editor textarea.project-desc-input{width:100%;padding:.5rem;border-radius:.5rem;border:1px solid #ccc;resize:vertical}.project-meta-display .project-title-display{font-size:2rem;font-weight:700;margin-bottom:.25rem}.project-meta-display .project-desc-display{color:#555;margin-bottom:.25rem}.project-meta-display .project-author-display{font-size:.875rem;color:#888}.action-btn{padding:.25rem .75rem;border-radius:.5rem;color:#fff;font-weight:600;cursor:pointer;margin-bottom:.25rem;transition:background-color .2s;border:none;display:inline-flex;align-items:center;gap:.25rem}.action-btn.views{background-color:#3b82f6}.action-btn.views:hover{background-color:#3182ce}.action-btn.love{background-color:#ef4444}.action-btn.love:hover{background-color:#dc2626}.action-btn.favourite{background-color:#facc15;color:#000}.action-btn.favourite:hover{background-color:#eab308}.action-btn.remix{background-color:#10b981}.action-btn.remix:hover{background-color:#059669}.action-btn.see-inside{background-color:#3b82f6}.action-btn.see-inside:hover{background-color:#2563eb}.action-btn.share{background-color:#8b5cf6}.action-btn.share:hover{background-color:#7c3aed}.action-btn.unshare{background-color:#374151}.action-btn.unshare:hover{background-color:#1f2937}.thumbnail-uploader input[type=file]{margin-top:.25rem}.thumbnail-uploader .uploading-text{display:inline-block;margin-left:.5rem;color:#6b7280;font-size:.875rem}.iframe-wrapper{min-height:360px}.iframe-container{width:80vw;max-width:1200px;aspect-ratio:4 / 3;box-shadow:0 4px 12px #0003;border-radius:1rem;overflow:hidden}.iframe-content{width:100%;height:100%}.comment-list{margin-top:1rem}.comment-item{background-color:#f3f4f6;padding:.75rem;border-radius:.5rem;margin-bottom:.5rem}.comment-header{display:flex;justify-content:space-between;font-size:.875rem;color:#4b5563;margin-bottom:.25rem}.comment-user{font-weight:600;color:#1d4ed8}.comment-date{font-size:.75rem;color:#6b7280}.comment-text{color:#111827}.reply-btn{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;margin-top:.25rem}.comment-form textarea,.reply-form textarea{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.5rem;resize:vertical}.comment-submit-btn,.reply-submit-btn{margin-top:.25rem;padding:.4rem .8rem;background-color:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer}.comment-submit-btn:hover,.reply-submit-btn:hover{background-color:#1d4ed8}.spinner{width:3rem;height:3rem;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.error-display,.loading-spinner{text-align:center}
