*{box-sizing:border-box}body{margin:0;font-family:sans-serif}#root{display:flex;flex-direction:column;height:100vh}.app-header{background-color:#333;color:#fff;padding:1rem;border-bottom:1px solid #ddd;flex-shrink:0}.app-header h1{margin:0;font-size:1.5rem}.app-main{display:flex;flex:1;overflow:hidden}.app-sidebar{width:40%;border-right:1px solid #ddd;display:flex;flex-direction:column;overflow:hidden}.app-detail{flex:1;overflow:auto;padding:1rem;background-color:#f9f9f9}.article-form{padding:1rem;border-bottom:1px solid #ddd}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem}.required{color:red}.form-group input,.form-group textarea{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-family:inherit;font-size:1rem}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#333;box-shadow:0 0 4px #0003}.article-form .btn-submit{width:100%;padding:.75rem;background-color:#333;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.article-form .btn-submit:hover{background-color:#555}.form-actions{display:flex;gap:.5rem}.form-actions .btn-submit{flex:1}.form-actions .btn-cancel{padding:.75rem;border-radius:4px;border:1px solid #ccc;background-color:#f2f2f2;color:#333;cursor:pointer;font-size:1rem}.form-actions .btn-cancel:hover{background-color:#e3e3e3}.open-form-button{padding:.75rem;margin:1rem;background-color:#333;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.open-form-button:hover{background-color:#555}.tab-container{display:flex;gap:.25rem;padding:0 1rem;margin-bottom:.5rem;border-bottom:2px solid #ddd}.tab-button{flex:1;padding:.75rem 1rem;background-color:transparent;color:#666;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.tab-icon{width:1.2rem;height:1.2rem;opacity:.6;transition:opacity .2s}.tab-button:hover{color:#333;background-color:#f5f5f5}.tab-button:hover .tab-icon{opacity:.9}.tab-button.active{color:#333;border-bottom-color:#333}.tab-button.active .tab-icon{opacity:1}.tab-button-small{flex:.5;font-size:.85rem}.article-list{display:flex;flex-direction:column;flex:1;overflow:auto}.form-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;justify-content:flex-end;align-items:flex-start;z-index:1000;padding:1.5rem}.form-drawer{width:min(480px,100%);max-height:calc(100% - 3rem);background:#fff;box-shadow:-2px 0 12px #0003;overflow:auto;border-radius:8px}.article-item{padding:.75rem;border-bottom:1px solid #eee;cursor:pointer}.article-item:hover{background-color:#f0f0f0}.article-item.active{background-color:#ddd}.article-title{font-weight:500}.article-meta{font-size:.8rem;color:#666;display:flex;justify-content:space-between;align-items:center;margin-top:.25rem}.article-open-button{border:none;background:transparent;padding:.2rem;cursor:pointer;line-height:0;opacity:.7}.article-open-button:hover{opacity:1}.article-open-icon{width:1.1rem;height:1.1rem}.badge{padding:.1rem .4rem;border-radius:4px;font-size:.75rem}.badge-read{background-color:#4caf50;color:#fff;padding:.2rem .4rem;border-radius:3px;font-size:.65rem;margin-right:.3rem}.article-date{margin-left:.5rem}.article-detail{padding:1rem}.detail-header{display:flex;justify-content:space-between;align-items:center}.detail-header h2{margin:0}.detail-close-button{border:none;background:transparent;font-size:1.8rem;line-height:1;color:#666;cursor:pointer;padding:0 .25rem}.detail-close-button:hover{color:#222}.detail-actions .btn-danger{background-color:#c62828;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.detail-url a{word-break:break-all;color:#1a0dab}.detail-flags{margin:.5rem 0}.detail-flags .checkbox{margin-right:1rem}.detail-memo{margin-top:1.5rem}.detail-memo textarea{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-family:inherit;font-size:1rem}.detail-meta{margin-top:1rem;font-size:.8rem;color:#666}.detail-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap;justify-content:flex-start;align-items:flex-end}.detail-actions .btn:not(.btn-delete){flex:0 1 auto}.detail-actions .btn-delete{margin-left:auto}.btn{padding:.5rem 1rem;border-radius:4px;border:1px solid #ccc;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-outline{background-color:#fff;color:#333}.btn-outline:hover{background-color:#f0f0f0}.btn-read{background-color:#4caf50;color:#fff;border-color:#4caf50}.btn-read:hover{background-color:#45a049}.btn-discard{background-color:#ff9800;color:#fff;border-color:#ff9800}.btn-discard:hover{background-color:#e68900}.btn-delete{background-color:transparent;color:#999;border:none;padding:.25rem 0;font-size:.85rem;text-decoration:underline;cursor:pointer}.btn-delete:hover{color:#666}.badge-discard{background-color:#ff9800;color:#fff;padding:.2rem .4rem;border-radius:3px;font-size:.65rem;margin-right:.3rem}@media (max-width: 900px){.app-sidebar{width:100%;border-right:none}.app-detail{width:100%;padding:.75rem}.form-overlay{padding:0;align-items:stretch}.form-drawer{width:100%;max-height:100%;border-radius:0}}
