: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;padding:0;min-width:320px;min-height:100vh;width:100%;height:100%}#root{width:100%;min-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}}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:loginFadeIn .3s ease}@keyframes loginFadeIn{0%{opacity:0}to{opacity:1}}.login-modal-content{position:relative;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:420px;padding:2rem;animation:loginSlideUp .3s ease;border:1px solid #e5e7eb}@keyframes loginSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.login-modal-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:#f3f4f6;color:#6b7280;border-radius:8px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.login-modal-close:hover{background:#e5e7eb;color:#374151;transform:rotate(90deg)}.login-modal-header{text-align:center;margin-bottom:2rem;padding-top:.5rem}.login-modal-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 .6rem}.login-modal-subtitle{font-size:.9rem;color:#6b7280;margin:0}.login-modal-form{display:flex;flex-direction:column;gap:1.2rem}.login-error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.85rem;animation:loginShake .4s ease}@keyframes loginShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-error-icon{font-size:1rem;flex-shrink:0}.login-form-group{display:flex;flex-direction:column;gap:.5rem}.login-form-label{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:#374151}.login-label-icon{font-size:.95rem}.login-form-input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.9rem;outline:none;transition:all .3s ease;background:#f9fafb;color:#1f2937;box-sizing:border-box}.login-form-input:focus{border-color:#1a73e8;background:#fff;box-shadow:0 0 0 3px #1a73e81a}.login-form-input:disabled{opacity:.6;cursor:not-allowed}.login-form-input::placeholder{color:#9ca3af}.login-submit-btn{width:100%;padding:.85rem 1.5rem;background:linear-gradient(135deg,#1a73e8,#4285f4);border:none;border-radius:10px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #1a73e84d}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #1a73e866}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:loginSpin .8s linear infinite}@keyframes loginSpin{to{transform:rotate(360deg)}}.login-form-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;padding-top:.5rem;border-top:1px solid #f3f4f6;margin-top:.5rem}.login-footer-text{font-size:.85rem;color:#6b7280}.login-switch-btn{background:none;border:none;color:#1a73e8;font-size:.85rem;font-weight:600;cursor:pointer;padding:0;transition:all .2s ease}.login-switch-btn:hover:not(:disabled){color:#1557b0;text-decoration:underline}.login-switch-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.login-modal-content{padding:1.5rem;width:95%}.login-modal-close{width:28px;height:28px;font-size:1rem}.login-modal-title{font-size:1.3rem}.login-modal-subtitle{font-size:.85rem}.login-form-input{padding:.7rem .9rem;font-size:.85rem}.login-submit-btn{padding:.75rem 1.2rem;font-size:.9rem}}.login-modal-overlay,.login-modal-content,.login-modal-close,.login-form-input,.login-submit-btn,.login-switch-btn{transition:all .3s ease}.add-website-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.add-website-modal{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.add-website-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.add-website-close:hover{background:#f0f0f0;color:#333}.add-website-header{padding:2rem 2rem 1rem;border-bottom:1px solid #eee}.add-website-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#333}.add-website-subtitle{margin:0;color:#666;font-size:.9rem}.add-website-form{padding:1.5rem 2rem 2rem}.add-website-error{background:#fee;color:#c33;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.add-website-error-icon{font-size:1.2rem}.add-website-form-group{margin-bottom:1.5rem}.add-website-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:500;color:#333;font-size:.9rem}.add-website-label-icon{font-size:1.1rem}.add-website-input,.add-website-select,.add-website-textarea{width:100%;padding:.75rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:.95rem;transition:all .2s;font-family:inherit}.add-website-input:focus,.add-website-select:focus,.add-website-textarea:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a}.add-website-input:disabled,.add-website-select:disabled,.add-website-textarea:disabled{background:#f5f5f5;cursor:not-allowed}.add-website-category-wrapper{display:flex;gap:.5rem;align-items:flex-start}.add-website-select{flex:1}.add-website-new-category-btn{padding:.75rem 1rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:.85rem;font-weight:500;white-space:nowrap;transition:all .2s;flex-shrink:0}.add-website-new-category-btn:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.add-website-new-category-btn:disabled{opacity:.6;cursor:not-allowed}.add-website-new-category-form{margin-top:.75rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.add-website-new-category-inputs{margin-bottom:.75rem}.add-website-create-category-btn{width:100%;padding:.65rem 1rem;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.add-website-create-category-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 2px 8px #10b9814d}.add-website-create-category-btn:disabled{opacity:.6;cursor:not-allowed}.add-website-icon-selector{margin-top:.5rem}.add-website-icon-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:.5rem;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:200px;overflow-y:auto}.add-website-icon-item{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:2px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:1.2rem;transition:all .2s;padding:0}.add-website-icon-item:hover:not(:disabled){border-color:#1a73e8;background:#eff6ff;transform:scale(1.1)}.add-website-icon-item.selected{border-color:#1a73e8;background:#dbeafe;box-shadow:0 0 0 2px #1a73e833}.add-website-icon-item:disabled{opacity:.5;cursor:not-allowed}.add-website-icon-custom{margin-top:.75rem;display:flex;gap:.5rem;align-items:center}.add-website-icon-custom .add-website-input{flex:1}.add-website-icon-clear{padding:.5rem 1rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.85rem;transition:all .2s;white-space:nowrap}.add-website-icon-clear:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.add-website-icon-clear:disabled{opacity:.6;cursor:not-allowed}.add-website-textarea{resize:vertical;min-height:80px}.add-website-submit{width:100%;padding:.85rem 1.5rem;background:#1a73e8;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.75rem}.add-website-submit:hover:not(:disabled){background:#1557b0;transform:translateY(-1px);box-shadow:0 4px 12px #1a73e84d}.add-website-submit:disabled{opacity:.6;cursor:not-allowed}.add-website-cancel{width:100%;padding:.75rem 1.5rem;background:#f5f5f5;color:#666;border:none;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .2s}.add-website-cancel:hover:not(:disabled){background:#e0e0e0}.add-website-cancel:disabled{opacity:.6;cursor:not-allowed}.add-website-btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}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:#f0f2f5;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;background:#f0f2f5}.header{background:#fff;box-shadow:0 2px 8px #00000014;position:sticky;top:0;z-index:100;border-bottom:1px solid #e5e7eb}.header-content{max-width:1400px;margin:0 auto;padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.header-logo{display:flex;align-items:center;gap:.6rem;flex-shrink:0;cursor:pointer}.logo-icon{width:34px;height:34px;background:#f3f4f6;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;transition:all .3s ease}.header-logo:hover .logo-icon{background:#e5e7eb;transform:scale(1.05)}.logo-text{font-size:1.1rem;font-weight:700;color:#1f2937;white-space:nowrap}.header-search{flex:1;max-width:500px;position:relative}.header-search .search-input{width:100%;padding:.55rem 2.6rem .55rem 1rem;border:2px solid #e5e7eb;border-radius:18px;font-size:.85rem;outline:none;transition:all .3s ease;background:#f9fafb;color:#1f2937}.header-search .search-input:focus{border-color:#1a73e8;background:#fff;box-shadow:0 4px 12px #1a73e826}.header-search .search-input::placeholder{color:#9ca3af}.search-btn{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1rem;cursor:pointer;padding:.3rem .5rem;transition:transform .2s}.search-btn:hover{transform:translateY(-50%) scale(1.1)}.header-user{display:flex;align-items:center;gap:.8rem;flex-shrink:0}.user-name{font-size:.85rem;color:#6b7280;font-weight:500;white-space:nowrap;padding:.4rem .9rem;background:#f3f4f6;border-radius:14px}.add-website-header-btn{padding:.45rem 1.1rem;background:#1a73e8;border:none;border-radius:14px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s;margin-right:.5rem}.add-website-header-btn:hover{background:#1557b0;transform:translateY(-1px);box-shadow:0 2px 8px #1a73e84d}.logout-btn{padding:.45rem 1.1rem;background:#fff;border:1px solid #e5e7eb;border-radius:14px;color:#6b7280;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .3s;white-space:nowrap}.logout-btn:hover{background:#f9fafb;border-color:#1a73e8;color:#1a73e8;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.main-wrapper{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:1.5rem;display:flex;gap:1.5rem}.sidebar{width:200px;flex-shrink:0;position:sticky;top:85px;height:fit-content;max-height:calc(100vh - 105px);overflow-y:auto}.sidebar-header{background:#fff;padding:.9rem 1.1rem;border-radius:10px 10px 0 0;border:1px solid #e5e7eb;border-bottom:2px solid #f3f4f6}.sidebar-title{font-size:.9rem;font-weight:600;color:#1f2937;margin:0;display:flex;align-items:center;gap:.4rem}.title-icon{font-size:.95rem}.category-nav{background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 10px 10px;padding:.4rem;display:flex;flex-direction:column;gap:.2rem}.category-tag-wrapper{display:flex;align-items:center;gap:.25rem;border-left:3px solid transparent;border-radius:6px;position:relative;transition:all .2s ease}.category-tag-wrapper:hover{background:#f9fafb}.category-tag-wrapper:hover .category-delete-btn{opacity:1}.category-tag{display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;background:transparent;color:#6b7280;text-align:left;flex:1}.category-tag:hover{background:transparent;color:#1f2937}.category-tag.active{background:#eff6ff;color:#1a73e8;font-weight:600}.category-delete-btn{padding:.25rem .5rem;background:#ef4444e6;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;opacity:0;transition:all .2s;color:#fff;margin-right:.5rem;flex-shrink:0}.category-delete-btn:hover{background:#dc2626;transform:scale(1.1)}.tag-icon{font-size:.95rem;line-height:1;flex-shrink:0}.tag-name{line-height:1;flex:1}.sidebar::-webkit-scrollbar{width:5px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#9ca3af}.main-content{flex:1;min-width:0}.website-container{min-height:400px}.loading,.empty{text-align:center;padding:3.5rem 2rem;color:#6b7280;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb}.loading-spinner{width:42px;height:42px;margin:0 auto 1.1rem;border:3px solid #f3f4f6;border-top:3px solid #1a73e8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-icon{font-size:3.2rem;margin-bottom:.8rem}.loading p,.empty p{font-size:.95rem;margin:0}.category-section{margin-bottom:1.5rem;background:#fff;border-radius:10px;border:1px solid #e5e7eb;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.1rem;background:#f9fafb;border-bottom:2px solid #e5e7eb;border-left:4px solid #1a73e8;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.section-header:hover{background:#f3f4f6}.section-title-wrapper{flex:1}.section-title{font-size:1rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:.5rem;margin:0}.section-icon{font-size:1.1rem}.section-count{font-size:.8rem;font-weight:500;color:#9ca3af;margin-left:.2rem}.collapse-btn{padding:.3rem .65rem;background:#fff;border:1px solid #e5e7eb;border-radius:5px;color:#6b7280;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s;flex-shrink:0}.collapse-btn:hover{background:#f3f4f6;color:#1f2937}.website-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;padding:1rem}.website-card{background:#fff;border-radius:10px;padding:0;transition:all .3s ease;box-shadow:0 2px 6px #0000000d;border:1px solid #e5e7eb;border-top:3px solid #e5e7eb;position:relative;display:flex;flex-direction:column}.website-card-content{padding:1.1rem;cursor:pointer;flex:1;display:flex;gap:.9rem}.website-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001a;border-color:#1a73e8}.website-card:hover .website-delete-btn,.website-card:hover .website-favorite-btn{opacity:1}.website-favorite-btn{position:absolute;top:.5rem;right:2.5rem;background:#ffc107e6;border:none;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;opacity:0;transition:all .2s;z-index:10;color:#fff}.website-favorite-btn:hover{background:#ff9800;transform:scale(1.1)}.website-delete-btn{position:absolute;top:.5rem;right:.5rem;background:#ef4444e6;border:none;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;opacity:0;transition:all .2s;z-index:10;color:#fff}.website-delete-btn:hover{background:#dc2626;transform:scale(1.1)}.website-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:10px;font-size:1.5rem;transition:all .3s ease}.website-card:hover .website-icon{transform:scale(1.05);background:#e5e7eb}.website-icon img{width:30px;height:30px;object-fit:contain}.default-icon{font-size:1.5rem}.website-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.35rem}.website-title{font-size:.9rem;font-weight:600;color:#1f2937;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .2s}.website-card:hover .website-title{color:#1a73e8}.website-description{font-size:.78rem;color:#6b7280;margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4}.footer{background:#fff;border-top:1px solid #e5e7eb;margin-top:auto}.footer-content{max-width:1400px;margin:0 auto;padding:1.1rem 1.5rem;text-align:center}.footer-text{font-size:.8rem;color:#9ca3af;margin:0}@media (max-width: 1024px){.main-wrapper{flex-direction:column}.sidebar{width:100%;position:static;max-height:none}.category-nav{flex-direction:row;flex-wrap:wrap;overflow-x:auto}.category-tag{border-left:none;border-bottom:3px solid transparent}}@media (max-width: 768px){.header-content{flex-wrap:wrap;gap:.8rem;padding:.7rem 1rem}.header-logo{order:1}.header-search{order:3;flex-basis:100%;max-width:100%}.header-user{order:2;margin-left:auto}.logo-text{font-size:1rem}.user-name{display:none}.main-wrapper{padding:1rem}.website-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.8rem;padding:.8rem}.website-card{padding:1rem}.website-icon{width:40px;height:40px}.section-header{padding:.75rem 1rem}.section-title{font-size:.9rem}.footer-content{padding:1rem}}@media (max-width: 480px){.website-grid{grid-template-columns:1fr}}
