:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #3178c6aa)}.card{padding:2em}.read-the-docs{color:#888}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.main-navigation{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:0;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.nav-container{max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.nav-brand h1{margin:0;font-size:1.5rem;font-weight:700;color:#fff}.nav-brand p{margin:.25rem 0 0;font-size:.85rem;opacity:.9}.nav-links{display:flex;gap:1rem}.nav-links a{padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;color:#fff;font-weight:500;transition:all .2s ease;background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.nav-links a:hover{background:#fff3;transform:translateY(-2px)}.nav-links a.active{background:#fff;color:#667eea;box-shadow:0 4px 12px #00000026}.nav-info{display:flex;align-items:center;gap:1rem}.github-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;text-decoration:none;color:#fff;font-size:.9rem;transition:all .2s ease;border:1px solid rgba(255,255,255,.3)}.github-link:hover{background:#ffffff1a;transform:translateY(-2px)}@media(max-width:768px){.nav-container{flex-direction:column;align-items:flex-start}.nav-links{width:100%;flex-direction:column}.nav-links a{width:100%;text-align:center}}.App{max-width:1400px;margin:0 auto;padding:1rem;text-align:left;height:100vh;box-sizing:border-box}h1{text-align:center;color:#646cff;margin-bottom:1.5rem;font-size:1.8rem}.app-container{display:flex;gap:2rem;height:calc(100vh - 100px);align-items:flex-start}.sidebar{flex:0 0 320px;overflow-y:auto;padding-right:.5rem;max-height:100%}.main-content{flex:1;min-width:0;display:flex;flex-direction:column;height:100%}h3{margin-top:0;color:#333;font-size:1.1rem;margin-bottom:.8rem}.jwt-token-section{background:#fff9e6;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #ffe082}.jwt-token-section h3{margin-bottom:.5rem;color:#f57c00;font-size:1rem}.token-input-group{display:flex;gap:.25rem;margin-bottom:.25rem}.token-input{flex:1;padding:.4rem;border:1px solid #ffd54f;border-radius:4px;font-size:.85rem;min-width:0}.save-token-btn,.clear-token-btn{padding:.4rem .6rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.save-token-btn{background:#4caf50;color:#fff}.clear-token-btn{background:#ef5350;color:#fff}.token-hint,.token-status{font-size:.75rem;margin:.3rem 0 0}.status-bar{background:#f5f5f5;padding:.8rem;border-radius:6px;margin-bottom:1rem;font-size:.85rem;min-height:4.5rem}.status-bar p{margin:.2rem 0}.status-bar button{width:100%;margin-top:.5rem;padding:.3rem;font-size:.8rem}.sync-result{font-size:.75rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:1.1em}.local-changes-indicator{display:flex;align-items:center;gap:.4rem;margin-top:.5rem;padding:.35rem .6rem;border-radius:4px;font-size:.8rem;transition:background .3s,border-color .3s}.local-changes-indicator.has-changes{background:#fff3e0;border:1px solid #ffb74d;color:#e65100}.local-changes-indicator.no-changes{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.local-changes-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background .3s}.local-changes-indicator.has-changes .local-changes-dot{background:#ff6d00;animation:pulse-dot 1.5s ease-in-out infinite}.local-changes-indicator.no-changes .local-changes-dot{background:#43a047}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.sync-controls{margin-bottom:1rem;padding:.8rem;background:#e3f2fd;border-radius:6px;display:flex;flex-direction:column;gap:.5rem}.sync-controls>button{padding:.5rem;background:#646cff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;height:36px;line-height:1}.sync-controls button:disabled{opacity:.6;cursor:not-allowed}.force-pull-btn{background:#ff9800!important;font-weight:600;height:36px;line-height:1}.force-pull-btn:hover:not(:disabled){background:#f57c00!important}.sync-row{display:flex;gap:.5rem}.sync-row button{flex:1}.fetch-btn{background:#5c6bc0!important;font-weight:500;height:36px;line-height:1}.fetch-btn:hover:not(:disabled){background:#3f51b5!important}.fetch-result{position:relative;padding:.5rem 1.8rem .5rem .6rem;border-radius:5px;font-size:.8rem;line-height:1.4}.fetch-no-changes{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.fetch-has-changes{background:#fff8e1;border:1px solid #ffe082;color:#f57f17}.fetch-error{background:#ffebee;border:1px solid #ef9a9a;color:#c62828}.fetch-dismiss-btn{position:absolute;top:.3rem;right:.3rem;background:none!important;border:none;color:#999;cursor:pointer;font-size:.75rem;padding:0 .3rem;height:auto;line-height:1}.fetch-dismiss-btn:hover{color:#333}.fetch-records-summary{margin-top:.3rem;display:flex;flex-direction:column;gap:.15rem}.fetch-record-item{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:#555}.fetch-record-id{font-family:monospace;color:#888;flex-shrink:0}.fetch-record-detail{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fetch-record-ver{font-family:monospace;color:#999;font-size:.7rem;flex-shrink:0}.fetch-record-more{font-size:.7rem;color:#999;font-style:italic}.auto-sync-controls{background:#ffffff80;border-radius:6px;padding:.5rem;border:1px dashed #90caf9}.auto-sync-toggle-row{display:flex;align-items:center;gap:.5rem}.auto-sync-btn{flex:1;padding:.5rem;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.85rem;transition:background .2s,box-shadow .2s}.auto-sync-on{background:#e53935!important;color:#fff;box-shadow:0 0 8px #e5393566}.auto-sync-on:hover:not(:disabled){background:#c62828!important}.auto-sync-off{background:#43a047!important;color:#fff}.auto-sync-off:hover:not(:disabled){background:#2e7d32!important}.auto-sync-indicator{font-size:.75rem;animation:pulse-dot 1.5s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.auto-sync-interval-row{margin-top:.4rem}.auto-sync-interval-label{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:#555}.auto-sync-interval-input{width:48px;padding:.2rem .3rem;border:1px solid #90caf9;border-radius:4px;font-size:.8rem;text-align:center}.gc-controls{display:flex;gap:.5rem}.gc-controls button{flex:1;font-size:.8rem;background:#607d8b}.conflicts-section{margin-bottom:1rem;padding:.8rem;background:#fff3e0;border-radius:6px;border:2px solid #ff9800}.conflicts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.conflicts-header h3{margin:0;color:#e65100;font-size:1rem}.toggle-conflicts-btn{padding:.3rem .6rem;background:#ff9800;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}.toggle-conflicts-btn:hover{background:#f57c00}.conflicts-content{margin-top:.5rem}.conflicts-actions{display:flex;gap:.3rem;margin-bottom:.5rem}.conflicts-actions button{flex:1;padding:.4rem;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500}.resolve-all-local-btn{background:#4caf50;color:#fff}.resolve-all-local-btn:hover{background:#45a049}.resolve-all-remote-btn{background:#2196f3;color:#fff}.resolve-all-remote-btn:hover{background:#1976d2}.clear-conflicts-btn{background:#9e9e9e;color:#fff}.clear-conflicts-btn:hover{background:#757575}.conflicts-list{max-height:300px;overflow-y:auto}.conflict-item{background:#fff;border:1px solid #ffb74d;border-radius:4px;padding:.6rem;margin-bottom:.5rem}.conflict-info{margin-bottom:.5rem}.conflict-id{font-size:.75rem;color:#666;font-family:monospace}.conflict-versions{font-size:.8rem;font-weight:600;color:#e65100;margin:.2rem 0}.conflict-reason{font-size:.75rem;color:#666;font-style:italic;margin:.2rem 0}.conflict-data{font-size:.75rem;color:#333;margin-top:.3rem;padding:.3rem;background:#f5f5f5;border-radius:3px}.conflict-actions{display:flex;gap:.3rem}.conflict-actions button{flex:1;padding:.4rem;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500}.resolve-local-btn{background:#4caf50;color:#fff}.resolve-local-btn:hover{background:#45a049}.resolve-remote-btn{background:#2196f3;color:#fff}.resolve-remote-btn:hover{background:#1976d2}.add-block{padding:1rem;background:#f9f9f9;border-radius:8px;border:1px solid #eee}.form-row{display:flex;gap:.5rem;margin-bottom:.8rem}.form-row label{flex:1;font-size:.85rem;font-weight:500}.form-row select,.form-row input,.form-row textarea{width:100%;box-sizing:border-box;padding:.4rem;margin-top:.2rem;border:1px solid #ccc;border-radius:4px}.add-btn{width:100%;padding:.6rem;background:#009688;color:#fff;border:none;border-radius:4px;font-weight:700;cursor:pointer}.add-btn:hover{background:#00897b}.user-info{font-size:.75rem;margin-top:.8rem;padding:.4rem;background:#fff;border-radius:4px;text-align:center}.blocks-list{flex:1;display:flex;flex-direction:column;overflow:hidden}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #eee;flex-shrink:0}.list-header h2{font-size:1.2rem;margin:0}.filters{display:flex;gap:.5rem}.filters select{padding:.3rem;border-radius:4px;border:1px solid #ccc;font-size:.9rem}.blocks-grid{flex:1;overflow-y:auto;padding-right:.5rem;display:flex;flex-direction:column;gap:.5rem}.block-item.compact{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center;padding:.6rem .8rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 3px #0000000d;font-size:.9rem}.block-item.compact:hover{border-color:#bbdefb;box-shadow:0 2px 5px #00000014}.block-main{min-width:0}.block-header-compact{display:flex;align-items:center;gap:.5rem;margin-bottom:.2rem}.block-type-badge{font-size:1rem}.block-title{font-weight:600;color:#2c3e50;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.block-id{color:#999;font-family:monospace;font-size:.75rem}.block-parent-tag{font-size:.75rem;background:#f0f0f0;padding:.1rem .4rem;border-radius:4px;color:#666;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.block-body-compact{color:#555;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.block-meta-compact{display:flex;flex-direction:column;align-items:flex-end;font-size:.75rem;color:#888;min-width:80px;gap:.1rem}.block-actions-compact{display:flex;gap:.25rem}.block-actions-compact button{background:none;border:1px solid #e0e0e0;cursor:pointer;font-size:1rem;padding:.3rem;border-radius:4px;transition:all .2s}.block-actions-compact button:hover{background:#f5f5f5;border-color:#ccc}.block-actions-compact button.delete-btn-icon:hover{background:#ffebee;border-color:#ffcdd2}.empty-state{text-align:center;margin-top:3rem;color:#999;font-style:italic}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#bbb}.blog-navigation{background:#f5f5f5;padding:1rem;border-radius:8px;margin-bottom:1rem}.blog-navigation button{width:100%;margin-bottom:.5rem;padding:.75rem;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.95rem;transition:all .2s ease;text-align:left}.blog-navigation button:hover{background:#f0f0f0;border-color:#646cff}.blog-navigation button.active{background:#646cff;color:#fff;border-color:#646cff}.blog-navigation button:last-child{margin-bottom:0}.blog-stats{background:#e8f5e9;padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.blog-stats h3{color:#2e7d32}.blog-stats p{margin:.25rem 0;display:flex;justify-content:space-between}.blog-list-view{height:100%;display:flex;flex-direction:column}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;overflow-y:auto;padding:1rem 0}.post-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.post-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-4px);border-color:#646cff}.post-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.post-card-header h3{margin:0;font-size:1.3rem;color:#333;flex:1;line-height:1.3}.badge-published{background:#4caf50;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-draft{background:#ff9800;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.post-excerpt{color:#666;line-height:1.6;margin-bottom:1rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.post-meta{display:flex;gap:1rem;font-size:.85rem;color:#999;margin-bottom:.75rem;flex-wrap:wrap}.post-tags{display:flex;gap:.5rem;flex-wrap:wrap}.tag{background:#e3f2fd;color:#1976d2;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.blog-create-view{max-width:800px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.blog-create-view h2{margin-top:0;color:#333;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:#555;margin-bottom:.5rem;font-size:.95rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.form-group textarea{resize:vertical;min-height:120px;line-height:1.6}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.create-btn{padding:.75rem 2rem;background:#646cff;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;font-weight:600;transition:all .2s ease}.create-btn:hover:not(:disabled){background:#535ac8;transform:translateY(-2px)}.create-btn:disabled{background:#ccc;cursor:not-allowed}.cancel-btn{padding:.75rem 2rem;background:#f5f5f5;color:#666;border:1px solid #ddd;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background:#e0e0e0}.blog-detail-view{max-width:900px;margin:0 auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow-y:auto}.post-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.back-btn{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.95rem;transition:all .2s ease}.back-btn:hover{background:#e0e0e0}.post-actions{display:flex;gap:.5rem}.publish-btn{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s ease}.publish-btn:hover{background:#45a049;transform:translateY(-2px)}.unpublish-btn{padding:.5rem 1rem;background:#ff9800;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s ease}.unpublish-btn:hover{background:#fb8c00}.delete-btn{padding:.5rem 1rem;background:#f44336;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s ease}.delete-btn:hover{background:#e53935}.post-detail h1{color:#333;font-size:2.5rem;margin-bottom:1rem;line-height:1.2}.post-info{display:flex;gap:1.5rem;color:#999;font-size:.9rem;margin-bottom:1rem;flex-wrap:wrap}.post-content{margin-top:2rem;line-height:1.8;color:#444;font-size:1.05rem}.post-content p{margin-bottom:1rem}.comments-section{margin-top:3rem;padding-top:2rem;border-top:2px solid #f0f0f0}.comments-section h3{color:#333;margin-bottom:1.5rem}.add-comment{margin-bottom:2rem}.add-comment textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;margin-bottom:.75rem;box-sizing:border-box;resize:vertical}.add-comment textarea:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.add-comment button{padding:.5rem 1.5rem;background:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s ease}.add-comment button:hover:not(:disabled){background:#535ac8}.add-comment button:disabled{background:#ccc;cursor:not-allowed}.comments-list{display:flex;flex-direction:column;gap:1rem}.comment-item{background:#f9f9f9;padding:1rem;border-radius:8px;border-left:3px solid #646cff}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.comment-author{font-weight:600;color:#333;font-size:.9rem}.comment-time{color:#999;font-size:.85rem}.delete-comment-btn{padding:.25rem .5rem;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s ease}.delete-comment-btn:hover{background:#e53935}.comment-content{color:#555;line-height:1.6;font-size:.95rem}.empty-comments{text-align:center;color:#999;padding:2rem;font-style:italic}@media(max-width:768px){.posts-grid{grid-template-columns:1fr}.blog-detail-view,.blog-create-view{padding:1rem}.post-detail h1{font-size:2rem}.post-info{font-size:.85rem;gap:.75rem}}
