: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;min-width:320px;min-height:100vh;width:100%;height:100vh}h1{font-size:3.2em;line-height:1.1}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}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5}.auth-container,.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-form,.login-form{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 25px #0000001a;width:100%;max-width:500px;min-width:400px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{color:#333;margin-bottom:.5rem;font-size:2rem}.auth-header h2{color:#666;font-size:1.3rem;font-weight:400}.login-form h1{color:#333;margin-bottom:2rem;font-size:2rem}.login-form p{color:#666;margin-bottom:2rem;font-size:1.1rem}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:.8rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{padding-right:3rem}.password-toggle{position:absolute;right:.8rem;background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.2rem;border-radius:4px;transition:background-color .2s ease}.password-toggle:hover{background-color:#f8f9fa}.auth-button{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s ease;margin-bottom:1.5rem}.auth-button:hover:not(:disabled){transform:translateY(-1px)}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-switch{text-align:center;color:#666;margin-bottom:1.5rem}.switch-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline}.switch-button:hover{color:#764ba2}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid #fcc}.test-login{text-align:center;margin-top:1rem;padding-top:1rem}.test-login hr{border:none;border-top:1px solid #eee;margin-bottom:1rem}.test-login p{color:#999;font-size:.9rem;margin-bottom:.5rem}.test-button{background-color:#f8f9fa;border:1px solid #dee2e6;color:#6c757d;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease}.test-button:hover{background-color:#e9ecef}.support-links{text-align:center;margin-top:1rem;padding-top:1rem}.support-links hr{border:none;border-top:1px solid #eee;margin-bottom:1rem}.support-links p{color:#666;font-size:.9rem;margin:0}.support-link{color:#667eea;text-decoration:none;font-weight:600;cursor:pointer;transition:color .2s ease}.support-link:hover{color:#764ba2;text-decoration:underline}.login-form button{background:#667eea;color:#fff;border:none;padding:16px 32px;border-radius:8px;cursor:pointer;font-size:1.2rem;font-weight:600;margin-top:1rem;transition:background-color .2s}.login-form button:hover{background:#5a6fd8}.app{height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid #e5e5e5;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;height:60px}.header h1{color:#333;font-size:1.5rem}.user-menu-container{position:relative}.user-menu{background:none;border:1px solid #ddd;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background-color .2s}.user-menu:hover{background-color:#f8f9fa}.user-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #0000001a;z-index:1000;min-width:150px;margin-top:4px}.dropdown-item{display:block;width:100%;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;transition:background-color .2s;border-radius:0}.dropdown-item:hover{background-color:#f8f9fa}.dropdown-item:first-child{border-top-left-radius:6px;border-top-right-radius:6px}.dropdown-item:last-child{border-bottom-left-radius:6px;border-bottom-right-radius:6px}.app-body{display:flex;flex:1;overflow:hidden;padding:1rem;gap:1rem;height:calc(100vh - 80px)}.sidebar{width:280px;min-width:250px;background:#fff;border-right:1px solid #e5e5e5;border-radius:6px;padding:1.5rem;overflow-y:auto;height:100%}.sidebar-section{margin-bottom:2rem}.sidebar-section h3{color:#666;font-size:.9rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.folder-item{padding:12px 16px;cursor:pointer;border-radius:8px;margin-bottom:6px;transition:background-color .2s;font-size:1rem}.folder-item:hover{background-color:#f8f9fa}.folder-item.active{background-color:#e3f2fd;color:#1976d2}.new-folder-btn,.ai-chat-btn{width:100%;padding:8px 12px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:6px;cursor:pointer;color:#666}.search-box input{width:100%;padding:8px 12px;border:1px solid #e5e5e5;border-radius:6px;font-size:.9rem}.main-content{flex:1;display:flex;gap:1rem;height:100%}.content-area{flex:1;background:#fff;border-radius:6px;overflow:hidden;height:100%}.ai-sidebar{width:320px;min-width:300px;background:#f8f9fa;border-radius:6px;border:1px solid #e5e5e5;display:flex;flex-direction:column;height:100%;overflow:hidden}.ai-sidebar-header{padding:1rem;background:#667eea;color:#fff;border-radius:6px 6px 0 0;border-bottom:1px solid #e5e5e5}.ai-sidebar-header h3{margin:0;font-size:1rem}.ai-sidebar-content{padding:1rem;flex:1;display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.current-memo-info{padding:.5rem;background:#f3f4f6;border-radius:4px;border:1px solid #e5e7eb;font-size:.875rem;color:#6b7280;text-align:center}.current-memo-info p{margin:0}.memo-list{height:100%;display:flex;flex-direction:column;padding:1rem}.memo-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.new-memo-btn{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer}.memo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;overflow-y:auto}.memo-card{background:#f8f9fa;border:1px solid #e5e5e5;border-radius:12px;padding:1.5rem;cursor:pointer;transition:transform .2s,box-shadow .2s;min-height:200px}.memo-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.memo-card h3{margin-bottom:.5rem;color:#333}.memo-preview{color:#666;margin-bottom:1rem;line-height:1.4}.memo-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}.tag{background:#e3f2fd;color:#1976d2;padding:2px 6px;border-radius:4px;margin-right:4px}.memo-date{color:#999}.memo-editor{height:100%;display:flex;flex-direction:column;overflow-y:auto;padding:1rem}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.back-btn{background:none;border:1px solid #ddd;padding:8px 16px;border-radius:6px;cursor:pointer}.editor-actions{display:flex;gap:.5rem}.save-btn{background:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer}.delete-btn{background:#f44336;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer}.editor-form{flex:1;display:flex;flex-direction:column;gap:1rem}.title-input{font-size:1.5rem;font-weight:700;border:none;border-bottom:2px solid #e5e5e5;padding:8px 0;outline:none}.title-input:focus{border-bottom-color:#667eea}.editor-meta{display:flex;gap:1rem}.folder-select,.tags-input{padding:8px 12px;border:1px solid #e5e5e5;border-radius:6px;flex:1}.content-textarea{flex:1;border:1px solid #e5e5e5;border-radius:6px;padding:1rem;font-family:inherit;font-size:1rem;line-height:1.6;resize:none;outline:none}.content-textarea:focus{border-color:#667eea}.format-toolbar{display:flex;gap:.5rem;padding:.5rem;background:#f8f9fa;border-radius:6px;border:1px solid #e5e5e5;margin-bottom:.5rem;flex-wrap:wrap}.format-btn{padding:.4rem .8rem;border:1px solid #d1d5db;background:#fff;border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s;white-space:nowrap}.format-btn:hover{background:#f3f4f6;border-color:#9ca3af}.format-btn.active{background:#667eea;color:#fff;border-color:#667eea}.format-btn:disabled{opacity:.5;cursor:not-allowed}.content-area{flex:1;display:flex;flex-direction:column}.content-preview{flex:1;border:1px solid #e5e5e5;border-radius:6px;padding:1rem;background:#fff;font-family:inherit;font-size:1rem;line-height:1.6;overflow-y:auto;overflow-x:hidden}.content-preview h1,.content-preview h2,.content-preview h3,.content-preview h4,.content-preview h5,.content-preview h6{margin:.5em 0;font-weight:700}.content-preview h1{font-size:2.2em}.content-preview h2{font-size:1.9em}.content-preview h3{font-size:1.6em}.content-preview li{list-style:none;margin:.2em 0}.content-preview li:before{content:"• ";margin-right:.5em}.ai-assistant{margin-top:1rem;border:1px solid #e5e5e5;border-radius:8px;background:#f8f9fa}.ai-controls{display:flex;gap:.5rem;padding:1rem;border-bottom:1px solid #e5e5e5}.ai-controls .ai-btn{padding:.5rem 1rem;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s}.ai-controls .ai-btn:hover{background:#f3f4f6;border-color:#9ca3af}.ai-controls .ai-btn:disabled{opacity:.5;cursor:not-allowed;background:#f9f9f9}.ai-chat-panel{border-top:1px solid #e5e5e5;background:#fff;display:block;position:relative;z-index:10}.ai-chat-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#667eea;color:#fff;font-weight:500}.ai-chat-header h3{margin:0;font-size:1rem}.ai-chat-header .close-btn{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background .2s}.ai-chat-header .close-btn:hover{background:#fff3}.ai-error{padding:.75rem 1rem;background:#fef2f2;color:#dc2626;border-left:4px solid #dc2626;margin:.5rem 1rem;border-radius:4px;font-size:.9rem}.ai-response{margin:1rem;padding:1rem;background:#f0f9ff;border-radius:6px;border-left:4px solid #0ea5e9}.ai-response-header{font-weight:500;color:#0369a1;margin-bottom:.5rem;font-size:.9rem}.ai-response-content{color:#374151;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.ai-input-area{display:flex;gap:.5rem;padding:1rem;background:#f9fafb;border-top:1px solid #e5e5e5}.ai-input{flex:1;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;outline:none;transition:border-color .2s}.ai-input:focus{border-color:#667eea;box-shadow:0 0 0 1px #667eea}.ai-input:disabled{background:#f3f4f6;color:#6b7280}.ai-send-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s;white-space:nowrap}.ai-send-btn:hover:not(:disabled){background:#5a67d8}.ai-send-btn:disabled{background:#9ca3af;cursor:not-allowed}.admin-panel{position:fixed;inset:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:2000}.admin-panel-container{background:#fff;border-radius:12px;width:95%;max-width:1400px;height:85%;overflow:hidden;display:flex;flex-direction:column}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e5e5;background:#f8f9fa}.admin-header h2{margin:0;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:4px 8px;border-radius:4px}.close-btn:hover{background:#e5e5e5}.admin-tabs{display:flex;border-bottom:1px solid #e5e5e5;background:#f8f9fa}.tab-btn{padding:12px 24px;border:none;background:none;cursor:pointer;font-size:1rem;color:#666;border-bottom:2px solid transparent;transition:all .2s}.tab-btn:hover{background:#e5e5e5;color:#333}.tab-btn.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.admin-content{flex:1;overflow-y:auto;padding:1.5rem;width:100%;max-width:100%}.stats-panel h3,.users-panel h3{margin-top:0;margin-bottom:1.5rem;color:#333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;width:100%}.stat-card{background:#f8f9fa;border:1px solid #e5e5e5;border-radius:8px;padding:1.5rem;text-align:center}.stat-card h4{margin:0 0 .5rem;color:#666;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:#333}.users-table{overflow-x:auto;width:100%}.users-table table{width:100%;border-collapse:collapse;margin-top:1rem}.users-table th,.users-table td{padding:12px;text-align:left;border-bottom:1px solid #e5e5e5}.users-table th{background:#f8f9fa;font-weight:600;color:#333}.users-table tr:hover{background:#f8f9fa}.role-badge{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:500}.role-badge.admin{background:#e3f2fd;color:#1976d2}.role-badge.user{background:#f3e5f5;color:#7b1fa2}.status-badge{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:500}.status-badge.active{background:#e8f5e8;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.user-actions{display:flex;gap:.5rem;flex-wrap:wrap}.action-btn{padding:4px 8px;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.toggle{background:#e3f2fd;color:#1976d2}.action-btn.toggle:hover:not(:disabled){background:#bbdefb}.action-btn.reset{background:#fff3e0;color:#f57c00}.action-btn.reset:hover:not(:disabled){background:#ffe0b2}.action-btn.delete{background:#ffebee;color:#c62828}.action-btn.delete:hover:not(:disabled){background:#ffcdd2}.error-message{background:#ffebee;color:#c62828;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #ffcdd2}.loading{text-align:center;padding:2rem;color:#666;font-size:1.1rem}.empty-state{text-align:center;padding:3rem;color:#666}.empty-state p{margin-bottom:1rem;font-size:1.1rem}.memo-folder{font-size:.8rem;font-weight:500;margin-top:.5rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:3000}.save-confirmation-modal{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:90%;text-align:center}.save-confirmation-modal h3{margin:0 0 1rem;color:#333}.save-confirmation-modal p{margin:0 0 2rem;color:#666}.modal-buttons{display:flex;gap:.5rem;justify-content:center}.modal-buttons button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.modal-buttons .save-btn{background:#4caf50;color:#fff}.modal-buttons .save-btn:hover{background:#45a049}.modal-buttons .discard-btn{background:#f44336;color:#fff}.modal-buttons .discard-btn:hover{background:#da190b}.modal-buttons .cancel-btn{background:#e5e5e5;color:#333}.modal-buttons .cancel-btn:hover{background:#d5d5d5}.context-menu{background:#fff;border:1px solid #e5e5e5;border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:120px}.context-menu-item{padding:8px 12px;cursor:pointer;font-size:.9rem;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.context-menu-item:hover{background-color:#f8f9fa}.context-menu-item:last-child{border-bottom:none}.context-menu-item.delete{color:#dc2626}.context-menu-item.delete:hover{background-color:#fef2f2}.modal-content{background:#fff;border-radius:12px;padding:1.5rem;max-width:500px;width:90%}.modal-content h3{margin:0 0 1rem;color:#333}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group input{width:100%;padding:8px 12px;border:1px solid #e5e5e5;border-radius:6px;font-size:1rem}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.color-picker{display:flex;gap:.5rem;flex-wrap:wrap}.color-option{width:32px;height:32px;border:2px solid #e5e5e5;border-radius:50%;cursor:pointer;transition:all .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#333;transform:scale(1.1);box-shadow:0 0 0 2px #3333}.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.5rem}.modal-actions button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.modal-actions button[type=button]{background:#e5e5e5;color:#333}.modal-actions button[type=button]:hover{background:#d5d5d5}.modal-actions button[type=submit]{background:#667eea;color:#fff}.modal-actions button[type=submit]:hover{background:#5a67d8}
