:root{--text: #6b6375;--text-h: #08060d;--bg: #fff;--border: #e5e4e7;--code-bg: #f4f3ec;--accent: #aa3bff;--accent-bg: rgba(170, 59, 255, .1);--accent-border: rgba(170, 59, 255, .5);--social-bg: rgba(244, 243, 236, .5);--shadow: rgba(0, 0, 0, .1) 0 10px 15px -3px, rgba(0, 0, 0, .05) 0 4px 6px -2px;--sans: system-ui, "Segoe UI", Roboto, sans-serif;--heading: system-ui, "Segoe UI", Roboto, sans-serif;--mono: ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 1024px){:root{font-size:16px}}@media (prefers-color-scheme: dark){:root{--text: #9ca3af;--text-h: #f3f4f6;--bg: #16171d;--border: #2e303a;--code-bg: #1f2028;--accent: #c084fc;--accent-bg: rgba(192, 132, 252, .15);--accent-border: rgba(192, 132, 252, .5);--social-bg: rgba(47, 48, 58, .5);--shadow: rgba(0, 0, 0, .4) 0 10px 15px -3px, rgba(0, 0, 0, .25) 0 4px 6px -2px}#social .button-icon{filter:invert(1) brightness(2)}}body{margin:0;width:100%;padding:0}#root{width:100%;max-width:100%;margin:0;padding:0;min-height:100vh;display:flex;flex-direction:column;box-sizing:border-box}h1,h2{font-family:var(--heading);font-weight:500;color:var(--text-h)}h1{font-size:56px;letter-spacing:-1.68px;margin:32px 0}@media (max-width: 1024px){h1{font-size:36px;margin:20px 0}}h2{font-size:24px;line-height:118%;letter-spacing:-.24px;margin:0 0 8px}@media (max-width: 1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);display:inline-flex;border-radius:4px;color:var(--text-h)}code{font-size:15px;line-height:135%;padding:4px 8px;background:var(--code-bg)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}.app{height:100vh;display:flex;flex-direction:column;width:100%;max-width:100%;margin:0;padding:0;overflow:hidden}.app-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:.6rem 20px;color:#fff;display:flex;justify-content:space-between;align-items:center;width:100%;position:fixed;top:0;left:0;z-index:1000;box-shadow:0 2px 8px #00000026;height:54px}.header-left{display:flex;align-items:center;gap:1.5rem}.app-header h1{display:flex;align-items:center;gap:.75rem;font-size:1.1rem;font-weight:600;letter-spacing:.5px;margin:0;line-height:1}.app-header h1 .logo{width:28px;height:28px;display:block}.logo-link{display:flex;align-items:center;gap:.75rem;color:#fff;text-decoration:none;transition:opacity .3s}.logo-link:hover{opacity:.9}.header-tabs{display:flex;gap:.5rem}.nav-tab{color:#fff;background:none;border:none;padding:.4rem .9rem;font-size:.88rem;cursor:pointer;border-radius:20px;transition:all .3s}.nav-tab:hover{background-color:#ffffff26}.nav-tab.active{background-color:#ffffff4d;font-weight:500}.header-right a{color:#fff;text-decoration:none;padding:.4rem .9rem;border-radius:20px;transition:all .3s;background-color:#ffffff1a;font-size:.88rem}.header-right a:hover{background-color:#ffffff40;transform:translateY(-1px)}main{flex:1;padding:0;width:100%;display:flex;margin:54px 0 0;max-width:100%;height:calc(100vh - 54px)}.manager-container{width:100%;height:100%;display:flex;flex-direction:column}.tab-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.site-manager{padding:2rem;height:100%;overflow-y:auto;background-color:#f5f5f5}.site-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.site-manager-header h2{font-size:1.5rem;color:#333;font-weight:600}.add-btn{padding:.6rem 1.2rem;background-color:#2196f3;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.add-btn:hover{background-color:#1976d2}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.site-card{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:all .3s;cursor:pointer}.site-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.site-card-content{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.site-logo{width:48px;height:48px;min-width:48px;border-radius:8px;overflow:hidden;background-color:#f5f5f5;display:flex;align-items:center;justify-content:center}.site-logo img{width:100%;height:100%;object-fit:contain}.site-logo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;font-size:1.2rem;font-weight:600}.site-info{flex:1;min-width:0}.site-name-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.site-name{font-size:1.1rem;font-weight:600;color:#333;word-break:break-all;margin:0}.site-url{font-size:.85rem;color:#666;word-break:break-all;line-height:1.4}.site-card-more{position:relative;margin-left:auto}.site-card-more .more-btn{padding:.4rem;background:transparent!important;border:none!important;outline:none!important;box-shadow:none!important;cursor:pointer;color:#999;border-radius:0!important;transition:color .3s;display:flex;align-items:center;justify-content:center;-webkit-appearance:none;-moz-appearance:none;appearance:none}.site-card-more .more-btn:hover{background:transparent!important;color:#666}.site-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 2px 8px #0000001a;min-width:100px;z-index:100}.site-menu-dropdown .menu-item{padding:.6rem 1rem;cursor:pointer;font-size:.85rem;color:#333;transition:background-color .2s}.site-menu-dropdown .menu-item:hover{background-color:#f5f5f5}.site-menu-dropdown .menu-item.delete{color:#f44336}.site-menu-dropdown .menu-item.delete:hover{background-color:#ffebee}.content-manager{padding:2rem;height:100%;display:flex;flex-direction:column;background-color:#f5f5f5;overflow:hidden}.content-manager-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.content-manager-header h2{font-size:1.5rem;color:#333;margin:0}.content-manager-header .subtitle{color:#666;font-size:.9rem}.recommendations-scroll-container{flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;min-height:0}.recommendations-scroll-container::-webkit-scrollbar{display:none}.recommendations-list{display:flex;flex-direction:column;gap:2rem;margin-top:2px;padding-bottom:2px}.date-group{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.date-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #eee}.date-label{font-size:1.1rem;font-weight:600;color:#333}.date-count{font-size:.85rem;color:#666;background-color:#f0f0f0;padding:.25rem .75rem;border-radius:12px}.content-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1rem}.content-card{background-color:#fafafa;border-radius:8px;padding:1rem;border:1px solid #e0e0e0;transition:all .3s}.content-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#ccc}.content-card.processed{border-left:4px solid #4caf50;opacity:.8}.content-card.pending{border-left:4px solid #ff9800}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.5rem}.content-title{font-size:1rem;font-weight:600;color:#333;margin:0;line-height:1.4;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:500;white-space:nowrap}.status-badge.status-pending{background-color:#fff3e0;color:#e65100}.status-badge.status-processed{background-color:#e8f5e9;color:#2e7d32}.status-badge.status-ignored{background-color:#f5f5f5;color:#9e9e9e}.content-url{display:block;font-size:.85rem;color:#2196f3;text-decoration:none;margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.content-url:hover{text-decoration:underline}.content-reason{font-size:.9rem;color:#555;line-height:1.5;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid #eee}.content-time{font-size:.8rem;color:#999}.card-actions{display:flex;gap:.5rem}.action-btn{padding:.35rem .75rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s}.action-btn.process{background-color:#4caf50;color:#fff}.action-btn.process:hover{background-color:#45a049}.action-btn.ignore{background-color:#9e9e9e;color:#fff}.action-btn.ignore:hover{background-color:#757575}.processed-label{font-size:.85rem;color:#4caf50;font-weight:500}.process-modal{min-width:400px}.process-modal .modal-subtitle{color:#666;font-size:.9rem;margin-bottom:1.5rem}.process-modal .form-group{margin-bottom:1rem}.process-modal label{display:block;font-size:.9rem;color:#333;margin-bottom:.5rem;font-weight:500}.process-modal select{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background-color:#fff}.process-modal select:focus{outline:none;border-color:#2196f3}.placeholder-page{padding:2rem;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f5f5;color:#666}.placeholder-page h2{font-size:1.5rem;color:#333;margin-bottom:1rem}.placeholder-page p{font-size:1rem}.journal-info{font-size:.85rem;color:#4caf50;font-weight:500;background-color:#e8f5e9;padding:.35rem .75rem;border-radius:4px;white-space:nowrap}.journal-manager{display:flex;gap:0;width:100%;height:100%;max-width:100%;overflow:hidden}.sidebar{flex:1;background-color:#fff;padding:1rem;border-right:1px solid #e0e0e0;height:100%;box-sizing:border-box;min-height:0;display:flex;flex-direction:column}.sidebar h2{margin-bottom:1rem;font-size:1.2rem;flex-shrink:0}.create-journal{margin-bottom:2rem;display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.create-journal input{padding:.5rem;border:1px solid #ddd;border-radius:4px}.create-journal button{padding:.5rem;background-color:#61dafb;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.create-journal button:hover{background-color:#21a1c4}.sidebar ul{list-style:none;flex:1;overflow-y:auto;min-height:0;max-height:calc(100vh - 240px);scrollbar-width:none;-ms-overflow-style:none}.sidebar ul::-webkit-scrollbar{display:none}.sidebar li{padding:.75rem;border-radius:4px;margin-bottom:.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .3s}.sidebar li:hover{background-color:#f0f0f0}.sidebar li.active{background-color:#e3f2fd;border-left:4px solid #2196f3}.sidebar li .journal-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:.5rem}.sidebar li .journal-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.type-selector{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.type-selector-row{display:flex;gap:.5rem;margin-bottom:.5rem}.type-select{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background-color:#fff;cursor:pointer}.type-select:focus{outline:none;border-color:#2196f3}.more-menu-container{position:relative}.more-btn{padding:.5rem;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .3s}.more-btn:hover{background-color:#f5f5f5;border-color:#999;color:#333}.more-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 2px 8px #0000001a;min-width:150px;z-index:100}.menu-item{padding:.75rem 1rem;cursor:pointer;font-size:.9rem;color:#333;transition:background-color .2s;text-align:center}.menu-item:hover{background-color:#f5f5f5}.menu-item:first-child{border-radius:4px 4px 0 0}.menu-item:last-child{border-radius:0 0 4px 4px}.menu-item.disabled{color:#999;cursor:not-allowed}.menu-item.disabled:hover{background-color:#fff}.empty-type-hint{text-align:center;padding:2rem 1rem;color:#999;font-size:.9rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-dialog{background-color:#fff;padding:1.5rem;border-radius:8px;width:90%;max-width:400px;box-shadow:0 4px 12px #00000026}.modal-dialog h3{margin-bottom:1rem;font-size:1.1rem}.modal-dialog input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;margin-bottom:1rem;box-sizing:border-box}.modal-dialog input:focus{outline:none;border-color:#2196f3}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem}.modal-actions button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.modal-actions .cancel-btn{background-color:#f5f5f5;color:#666}.modal-actions .cancel-btn:hover{background-color:#e0e0e0}.modal-actions .confirm-btn{background-color:#2196f3;color:#fff}.modal-actions .confirm-btn:hover{background-color:#1976d2}.type-list{list-style:none;margin-bottom:1rem}.type-list li{padding:.75rem;border-radius:4px;margin-bottom:.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .3s;background-color:#f5f5f5}.type-list li:hover{background-color:#e0e0e0}.type-list li.active{background-color:#e3f2fd;border-left:4px solid #2196f3}.type-list li .type-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:.5rem}.delete-type-btn{background:none;border:none;color:#999;font-size:1.2rem;cursor:pointer;padding:0 .25rem;line-height:1;opacity:0;transition:opacity .3s,color .3s}.type-list li:hover .delete-type-btn{opacity:1}.delete-type-btn:hover{color:#f44336}.create-type{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.create-type input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.create-type button{padding:.5rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.create-type button:hover{background-color:#388e3c}.journal-list{list-style:none;flex:1;overflow-y:auto;min-height:0;max-height:calc(100vh - 400px);scrollbar-width:none;-ms-overflow-style:none}.journal-list::-webkit-scrollbar{display:none}.delete-journal-btn{width:22px;height:22px;border-radius:50%;border:none;background-color:#f44336;color:#fff;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .3s;opacity:0}.sidebar li:hover .delete-journal-btn{opacity:1}.delete-journal-btn:hover{background-color:#d32f2f}.delete-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;display:flex;justify-content:center;align-items:center;z-index:2000}.delete-confirm-dialog{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 8px 32px #0000001f;min-width:320px;max-width:400px;text-align:center}.delete-confirm-dialog .warning-icon{width:48px;height:48px;margin:0 auto 1rem;background-color:#fff3e0;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#ff9800;font-size:1.5rem}.delete-confirm-dialog h3{margin-bottom:.75rem;font-size:1.1rem;color:#333;font-weight:600}.delete-confirm-dialog .confirm-message{color:#666;font-size:.9rem;line-height:1.5;margin-bottom:1.5rem}.delete-confirm-actions{display:flex;justify-content:center;gap:.75rem}.delete-confirm-actions button{padding:.6rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s;min-width:80px}.delete-confirm-actions .cancel-btn{background-color:#f5f5f5;color:#666}.delete-confirm-actions .cancel-btn:hover{background-color:#e0e0e0}.delete-confirm-actions .confirm-delete-btn{background-color:#f44336;color:#fff}.delete-confirm-actions .confirm-delete-btn:hover{background-color:#d32f2f}.status{font-size:.8rem;padding:.25rem .5rem;border-radius:12px}.status.draft{background-color:#ffecb3;color:#ff8f00}.status.published{background-color:#c8e6c9;color:#2e7d32}.main-content{flex:3;background-color:#fff;padding:0;overflow:hidden;min-width:0;height:100%;box-sizing:border-box;display:flex;flex-direction:column}.preview-sidebar{flex:3;background-color:#fff;padding:1rem;overflow-y:auto;border-left:1px solid #e0e0e0;height:100%;box-sizing:border-box}.preview-sidebar h2{margin-bottom:1rem;font-size:1.2rem}.preview-content{background-color:#f9f9f9;border-radius:6px;padding:1rem;min-height:400px;position:relative}.preview-content pre{white-space:pre-wrap;font-family:inherit;font-size:.9rem;line-height:1.5;margin:0 0 2rem}.copy-btn{position:absolute;bottom:1rem;right:1rem;padding:.5rem 1rem;background-color:#61dafb;color:#333;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:.9rem}.copy-btn:hover{background-color:#21a1c4;color:#fff}.journal-editor{padding:1.5rem;height:100%;max-height:calc(100vh - 54px);box-sizing:border-box;display:flex;flex-direction:column;overflow:hidden}.journal-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-shrink:0}.journal-editor h2,.journal-actions{margin-bottom:0}.publish-btn{padding:.5rem 1.25rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:.9rem}.publish-btn:hover{background-color:#388e3c}.publish-btn:disabled{background-color:#ccc;cursor:not-allowed}.categories-section{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column;scrollbar-width:none;-ms-overflow-style:none}.categories-section::-webkit-scrollbar{display:none}.categories-section h3{margin-bottom:1rem;flex-shrink:0}.add-category{margin-bottom:2rem;display:flex;gap:.5rem;flex-shrink:0}.add-category input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px}.add-category button{padding:0 1rem;background-color:#61dafb;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.add-category button:hover{background-color:#21a1c4}.categories-list{flex:1;min-height:0}.category{background-color:#f9f9f9;border-radius:8px;padding:1rem;margin-bottom:1.5rem;cursor:move;transition:box-shadow .3s,transform .2s}.category.dragging{opacity:.5;box-shadow:0 4px 8px #0003}.category.drag-over{box-shadow:0 0 0 2px #2196f3;background-color:#e3f2fd}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.category-header h4{margin:0;color:#2196f3}.delete-category-btn{width:22px;height:22px;border-radius:50%;border:none;background-color:#f44336;color:#fff;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .3s;opacity:0}.category-header:hover .delete-category-btn{opacity:1}.delete-category-btn:hover{background-color:#d32f2f}.category h4{margin-bottom:0;color:#2196f3}.add-item{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.add-item.compact{gap:.3rem}.add-item input,.add-item textarea{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.add-item textarea{resize:vertical;min-height:80px}.title-input-wrapper{display:flex;gap:.5rem;align-items:stretch}.title-input-wrapper input{flex:1}.fetch-title-btn{padding:.5rem 1rem;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;white-space:nowrap;transition:background-color .3s}.fetch-title-btn:hover{background-color:#1976d2}.fetch-title-btn:active{background-color:#1565c0}.fetch-title-btn:disabled{background-color:#90caf9;cursor:not-allowed}.fetch-title-btn.loading{background-color:#90caf9;cursor:wait}.show-add-form-btn{background:none;border:none;color:#2196f3;cursor:pointer;font-size:.9rem;padding:.5rem 0;text-align:left;transition:color .3s}.show-add-form-btn:hover{color:#1976d2}.add-item-actions{display:flex;gap:.5rem;justify-content:flex-end}.add-item-actions button{padding:.3rem .8rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .3s}.cancel-add-btn{background-color:#fff;color:#666;border:1px solid #ddd}.cancel-add-btn:hover{background-color:#f5f5f5;border-color:#ccc}.confirm-add-btn{background-color:#2196f3;color:#fff}.confirm-add-btn:hover{background-color:#1976d2}.char-count{font-size:.8rem;color:#999;text-align:right;margin-top:-.3rem;margin-bottom:.3rem}.add-item button{align-self:flex-start;padding:.5rem 1rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:.9rem}.add-item button:hover{background-color:#388e3c}.item{background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:1rem;margin-bottom:.5rem;position:relative;cursor:grab;transition:box-shadow .2s}.item:active{cursor:grabbing}.item.dragging{opacity:.7;box-shadow:0 4px 8px #00000026}.item.drag-over{border-top:3px solid #2196f3}.drag-handle{position:absolute;left:.25rem;top:50%;transform:translateY(-50%);width:16px;height:30px;display:flex;align-items:center;justify-content:center;cursor:grab;color:#ccc;font-size:.7rem;line-height:1;-webkit-user-select:none;user-select:none;opacity:0;transition:opacity .2s}.item:hover .drag-handle{opacity:1}.drag-handle:hover{color:#666;background-color:#f0f0f0;border-radius:3px}.item:hover .edit-btn,.item:hover .delete-btn{opacity:1}.edit-btn,.delete-btn{position:absolute;top:.5rem;opacity:0;transition:opacity .3s,background-color .3s;padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}.edit-btn{right:3.5rem;background-color:#ffc107;color:#333}.edit-btn:hover{background-color:#e0a800}.delete-btn{right:.5rem;background-color:#f44336;color:#fff}.delete-btn:hover{background-color:#d32f2f}.edit-form{display:flex;flex-direction:column;gap:.5rem}.edit-form input,.edit-form textarea{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.edit-actions button{padding:.3rem .8rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .3s}.edit-actions button:first-child{background-color:#4caf50;color:#fff}.edit-actions button:first-child:hover{background-color:#388e3c}.edit-actions button:last-child{background-color:#9e9e9e;color:#fff}.edit-actions button:last-child:hover{background-color:#757575}.items-list{list-style:none}.item h5{margin-bottom:.5rem;color:#333}.item a{color:#2196f3;text-decoration:none;margin-bottom:.5rem;display:block;word-break:break-all;font-size:.9rem}.item p{color:#666;font-size:.9rem;line-height:1.4}.empty-state{display:flex;justify-content:center;align-items:center;height:300px;color:#999;font-size:1.2rem}.journal-list h2{margin-bottom:2rem}.journals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem}.journal-card{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:transform .3s,box-shadow .3s}.journal-card:hover{transform:translateY(-5px);box-shadow:0 4px 8px #0000001a}.journal-card h3{margin-bottom:.5rem;color:#333}.publish-date{font-size:.9rem;color:#999;margin-bottom:1rem}.category-preview{display:flex;flex-wrap:wrap;gap:.5rem}.category-tag{background-color:#e3f2fd;color:#2196f3;padding:.25rem .75rem;border-radius:12px;font-size:.8rem}.category-tag.more{background-color:#f0f0f0;color:#666}.journal-detail{background-color:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;margin-top:2rem}.export-section{margin:2rem 0;padding:1rem;background-color:#f9f9f9;border-radius:8px;display:flex;align-items:center;gap:1rem}.export-section select{padding:.5rem;border:1px solid #ddd;border-radius:4px}.export-section button{padding:.5rem 1rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.export-section button:hover{background-color:#388e3c}.export-content{margin:2rem 0}.export-content pre{background-color:#f0f0f0;padding:1rem;border-radius:4px;overflow-x:auto;white-space:pre-wrap;font-family:Courier New,Courier,monospace}.categories-content{margin-top:2rem}.category-section{margin-bottom:2rem}.category-section h3{margin-bottom:1rem;color:#2196f3;border-bottom:2px solid #e3f2fd;padding-bottom:.5rem}.content-item{background-color:#f9f9f9;border-radius:4px;padding:1rem;margin-bottom:1rem;list-style:none}.content-item h4{margin-bottom:.5rem;color:#333}.content-item a{color:#2196f3;text-decoration:none;margin-bottom:.5rem;display:block}.content-item p{color:#666;font-size:.9rem}.user-manager{padding:2rem;height:100%;display:flex;flex-direction:column;background-color:#f5f5f5;overflow:hidden}.user-manager-header{margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.user-manager-header h2{font-size:1.5rem;color:#333;margin:0}.add-btn{padding:.6rem 1.2rem;background-color:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.add-btn:hover{background-color:#5a67d8}.search-bar{margin-bottom:1.5rem;flex-shrink:0}.search-bar form{display:flex;gap:.5rem}.search-bar input{flex:1;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.search-bar button{padding:.6rem 1.2rem;background-color:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer}.user-table-container{flex:1;overflow-y:auto;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;scrollbar-width:none;-ms-overflow-style:none}.user-table-container::-webkit-scrollbar{display:none}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.user-table th{background-color:#f8f9fa;font-weight:600;color:#333;position:sticky;top:0}.user-table tr:hover{background-color:#f8f9fa}.role-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.role-badge.role-admin{background-color:#e3f2fd;color:#1976d2}.role-badge.role-user{background-color:#f5f5f5;color:#666}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.status-badge.status-active{background-color:#e8f5e9;color:#2e7d32}.status-badge.status-disabled{background-color:#ffebee;color:#c62828}.action-buttons{display:flex;gap:.5rem}.password-cell{display:flex;align-items:center;gap:.5rem}.password-cell span{font-family:monospace;font-size:.9rem;color:#666}.view-password-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:.2rem;opacity:.6;transition:opacity .2s}.view-password-btn:hover{opacity:1}.confirm-dialog{text-align:center;max-width:400px}.confirm-dialog h3{margin-bottom:1rem;color:#333}.confirm-dialog p{margin-bottom:.5rem;color:#666}.confirm-dialog .confirm-hint{font-size:.85rem;color:#999;margin-bottom:1.5rem}.confirm-dialog strong{color:#333}.danger-btn{background-color:#ef5350!important}.danger-btn:hover{background-color:#d32f2f!important}.role-select{padding:.35rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.8rem;cursor:pointer}.status-btn{padding:.35rem .75rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s}.status-btn.disable{background-color:#ffebee;color:#c62828}.status-btn.disable:hover{background-color:#ef5350;color:#fff}.status-btn.enable{background-color:#e8f5e9;color:#2e7d32}.status-btn.enable:hover{background-color:#66bb6a;color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem;flex-shrink:0}.pagination button{padding:.5rem 1rem;border:1px solid #ddd;background-color:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.pagination button:hover:not(:disabled){background-color:#667eea;color:#fff;border-color:#667eea}.pagination button:disabled{opacity:.5;cursor:not-allowed}.page-info{color:#666;font-size:.9rem}@media (max-width: 1200px){.preview-sidebar{flex:2}}@media (max-width: 992px){.journal-manager{flex-direction:column}.sidebar,.main-content,.preview-sidebar{width:100%;height:auto}.preview-sidebar{margin-top:1rem}.journals-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.export-section{flex-direction:column;align-items:stretch}}@media (max-width: 768px){.journals-grid{grid-template-columns:1fr}}.toast-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;z-index:3000;pointer-events:none}.toast-message{background-color:#000c;color:#fff;padding:1rem 2rem;border-radius:8px;font-size:1rem;animation:fadeInOut 2s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-20px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.login-fullscreen{height:100vh;overflow:hidden}.login-fullscreen .login-container{min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 54px);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:2rem}.login-box{background:white;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;color:#667eea;margin:0 0 .5rem}.login-header p{color:#666;font-size:1rem;margin:0}.login-form .form-group{margin-bottom:1.5rem}.login-form label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.login-form input{width:100%;padding:.75rem 1rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s,box-shadow .3s}.login-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-form input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-error{background-color:#ffebee;color:#c62828;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.remember-me{margin-bottom:1.5rem}.checkbox-label{display:inline-flex!important;flex-direction:row!important;align-items:center!important;cursor:pointer;font-size:.9rem;color:#666;-webkit-user-select:none;user-select:none;white-space:nowrap}.checkbox-label input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;width:0;height:0;margin:0}.checkmark{width:16px;height:16px;border:2px solid #ddd;border-radius:3px;margin-right:8px;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;vertical-align:middle}.checkbox-label:hover .checkmark{border-color:#667eea}.checkbox-label input[type=checkbox]:checked+.checkmark{background-color:#667eea;border-color:#667eea}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"✓";color:#fff;font-size:12px;line-height:1}.checkbox-label input[type=checkbox]:disabled+.checkmark{opacity:.5;cursor:not-allowed}.login-btn{width:100%;padding:.875rem;background-color:#667eea;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s}.login-btn:hover:not(:disabled){background-color:#5a67d8}.login-btn:disabled{background-color:#a0aec0;cursor:not-allowed}.login-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #eee}.login-footer p{color:#999;font-size:.85rem;margin:0}.user-info{color:#333;font-size:.9rem;margin-right:1rem;font-weight:500}.logout-btn{padding:.4rem 1rem;background-color:transparent;color:#667eea;border:1px solid #667eea;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .3s}.logout-btn:hover{background-color:#667eea;color:#fff}.journal-list-container{display:flex;height:calc(100vh - 54px);overflow:hidden;width:100%;max-width:1440px;margin:0 auto;box-shadow:0 0 20px #0000001a}.journal-sidebar{flex:0 0 320px;width:320px;background-color:#f5f5f5;border-right:1px solid #ddd;padding:2rem;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;box-sizing:border-box}.journal-sidebar::-webkit-scrollbar{display:none}.type-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.section-title{font-size:.85rem;color:#999;font-weight:400;margin-bottom:.75rem}.type-tags{display:flex;flex-wrap:wrap;gap:.5rem}.type-tag{padding:.35rem .75rem;border-radius:4px;border:none;background-color:transparent;color:#666;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.type-tag:hover{background-color:#f5f5f5;color:#333}.type-tag.active{background-color:#e3f2fd;color:#2196f3}.journal-list-user{list-style:none;padding:0}.journal-list-user li{padding:.6rem 1rem;margin-bottom:.4rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s;border-left:3px solid transparent}.journal-list-user li:hover{background-color:#fff;border-left-color:#2196f3}.journal-list-user li.active{background-color:#fff;border-left-color:#2196f3;color:#2196f3;font-weight:500}.type-section{margin-bottom:3rem}.type-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #2196f3}.type-header h2{color:#2196f3;font-size:1.5rem;font-weight:600}.journal-sidebar h2{margin-bottom:1rem;color:#333;font-size:1.2rem}.journal-sidebar .journal-list{list-style:none;padding:0}.journal-sidebar .journal-list li{padding:.75rem 1rem;margin-bottom:.5rem;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:.9rem}.journal-sidebar .journal-list li:hover{background-color:#e0e0e0}.journal-sidebar .journal-list li.active{background-color:#2196f3;color:#fff}.journal-content{flex:1 1 auto;padding:2rem;overflow-y:auto;background-color:#fff;scrollbar-width:none;-ms-overflow-style:none;box-sizing:border-box}.journal-content::-webkit-scrollbar{display:none}.journal-detail{max-width:100%;word-wrap:break-word;overflow-wrap:break-word}.journal-section{margin-bottom:3rem}.journal-header-simple{margin-bottom:1.5rem}.journal-header-simple h1{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.journal-header-simple .publish-date{color:#999;font-size:.85rem}.journal-body{padding:0}.category-block{margin-bottom:1.5rem;background-color:#f8f9fa;border-radius:8px;padding:1rem 1.25rem;border:1px solid #e9ecef}.category-block .category-name{color:#333;font-size:1rem;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.category-items{display:flex;flex-direction:column}.category-items .item-header{margin-top:1.25rem}.category-items .item-header:first-child{margin-top:0}.item-header{display:flex;align-items:baseline;gap:.5rem}.item-number{color:#666;font-size:.9rem;flex-shrink:0}.item-title{color:#333;font-size:1rem}.item-row{display:flex;align-items:flex-start;gap:.25rem}.item-label{color:#999;font-size:.85rem;flex-shrink:0}.item-link{color:#2196f3;font-size:.85rem;word-break:break-all;text-decoration:none}.item-link:hover{text-decoration:underline;color:#1976d2}.item-reason{color:#666;font-size:.85rem;line-height:1.5}.journal-divider{border:none;border-top:1px solid #eee;margin:2rem 0}.journal-content .empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:#999}@media (max-width: 768px){.journal-list-container{flex-direction:column}.journal-sidebar{width:100%;height:200px;border-right:none;border-bottom:1px solid #ddd}.journal-content{padding:1rem}}
