body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;padding:20px}.login-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.login-title{text-align:center;margin-bottom:1.5rem;color:#333}.login-form{display:flex;flex-direction:column;gap:1rem}.submit-button{background-color:#4a90e2;color:#fff;border:none;padding:.75rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.login-links{margin-top:1.5rem;text-align:center;color:#666}.login-links a{color:#4a90e2;text-decoration:none}.login-links a:hover{text-decoration:underline}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;padding:20px}.register-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.register-title{text-align:center;margin-bottom:1.5rem;color:#333}.register-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:500;color:#555}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.form-hint{display:block;margin-top:.25rem;color:#666;font-size:.85rem}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;border:1px solid #fcc;text-align:center}.success-message{background-color:#e8f7ef;color:#2d8c4e;padding:.75rem;border-radius:4px;border:1px solid #b8e6cb;text-align:center}.submit-button{background-color:#4a90e2;color:#fff;border:none;padding:.75rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.submit-button:hover:not(:disabled){background-color:#3a7bc8}.submit-button:disabled{background-color:#ccc;cursor:not-allowed}.register-links{margin-top:1.5rem;text-align:center;color:#666}.register-links a{color:#4a90e2;text-decoration:none}.register-links a:hover{text-decoration:underline}.terms-note{font-size:.9rem;color:#666;margin-top:1rem;text-align:center}.terms-note a{color:#4a90e2}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal{background:var(--card-bg);border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;border:1px solid var(--border-color)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal h2{margin:0;padding:1.5rem 1.5rem 1rem;font-size:1.5rem;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.modal form{padding:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:500;font-size:.95rem}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3182ce1a;background:var(--bg-primary)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);opacity:.7}.form-group textarea{resize:vertical;min-height:100px}.error-message{background:#e53e3e1a;color:var(--error-color);padding:.75rem;border-radius:8px;margin-bottom:1.5rem;border:1px solid var(--error-color);font-size:.95rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-actions button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.modal-actions button[type=button]{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.modal-actions button[type=button]:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary);border-color:var(--primary-color)}.modal-actions button[type=submit]{background:var(--primary-color);color:#fff}.modal-actions button[type=submit]:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.modal-actions button:disabled{opacity:.5;cursor:not-allowed}.dark-mode .modal,.dark-mode .modal-actions button[type=button]{border-color:var(--border-color)}@media(max-width:768px){.modal{width:95%;margin:1rem}.modal h2{padding:1rem 1rem .5rem;font-size:1.3rem}.modal form{padding:1rem}.modal-actions{flex-direction:column;gap:.75rem}.modal-actions button{width:100%}}@media(max-width:480px){.modal h2{font-size:1.2rem}.form-group input,.form-group textarea{padding:.6rem}}.circle-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;padding:2rem 1.5rem;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-sm);min-height:180px;display:flex;flex-direction:column}.circle-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.circle-card h3{margin:0 0 .75rem;font-size:1.4rem;font-weight:600;color:var(--text-primary);line-height:1.3}.circle-card p{color:var(--text-secondary);margin:0 0 1.5rem;font-size:1rem;line-height:1.5;flex:1}.circle-meta{display:flex;gap:1.5rem;align-items:center;font-size:1rem;color:var(--text-secondary);border-top:2px solid var(--border-color);padding-top:1.25rem;margin-top:auto}.badge{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.role{text-transform:capitalize;font-weight:500;color:var(--text-primary);background:var(--hover-bg);padding:.25rem .75rem;border-radius:20px;font-size:.9rem}.member-count{margin-left:auto;color:var(--text-muted);font-size:.95rem;display:flex;align-items:center;gap:.25rem}.member-count:before{content:"👥";font-size:1rem;opacity:.8}.dark-mode .circle-card{border-color:var(--border-color)}.dark-mode .role{background:var(--bg-secondary)}@media(max-width:768px){.circle-card{padding:1.5rem;min-height:160px}.circle-card h3{font-size:1.2rem}.circle-meta{gap:1rem;flex-wrap:wrap}.member-count{margin-left:0;width:100%;justify-content:flex-end}}.post-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}.post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.post-author-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;text-transform:uppercase}.post-author{font-weight:600;color:var(--text-primary)}.post-date{font-size:.85rem;color:var(--text-muted)}.post-content h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1.1rem}.post-content p{color:var(--text-secondary);line-height:1.6;margin:0 0 .5rem}.post-circle{font-size:.85rem;color:var(--primary-color);font-style:italic}.post-actions{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.post-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem 1rem;border-radius:20px;transition:all .2s;display:flex;align-items:center;gap:.5rem}.post-action-btn:hover{background:var(--hover-bg);color:var(--primary-color)}@media(max-width:768px){.post-card{padding:1rem}.post-actions{flex-wrap:wrap;gap:.5rem}.post-action-btn{padding:.5rem;flex:1;justify-content:center}}.welcome-section{margin-bottom:2rem}.welcome-section h1{font-size:1.8rem;color:var(--text-primary);margin-bottom:.5rem}.welcome-section p{color:var(--text-secondary);font-size:1rem}.action-buttons{display:flex;gap:1rem;margin:2rem 0}.primary-btn{background:var(--primary-color);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;border:none;cursor:pointer;transition:background .2s;box-shadow:var(--shadow-sm)}.circles-section{margin:2rem 0}.section-header{display:flex;justify-content:space-between;align-items:center;margin:2rem 0 1rem}.section-header h2{margin:0;color:var(--text-primary);font-size:1.3rem}.circles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin:1.5rem 0}.feed-section{margin:2rem 0}.posts-feed{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.create-post-section{margin:2rem 0;padding:1.5rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}@media(max-width:1024px){.dashboard-main{padding:1.5rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}}@media(max-width:768px){.dashboard-main{padding:1rem}.welcome-section h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons button{width:100%}}@media(max-width:480px){.dashboard-main{padding:.75rem}.stat-card{padding:1rem}.stat-number{font-size:1.5rem}.empty-state{padding:2rem 1rem}}.dashboard-main{padding:1rem}.circles-grid{grid-template-columns:1fr}.welcome-section h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons button{width:100%}.post-meta{flex-direction:column;gap:.5rem}.member-row{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;transition:all .2s}.member-row:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.member-info{display:flex;align-items:center;gap:1rem;flex:1}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;text-transform:uppercase}.member-details{flex:1}.member-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.owner-tag{color:var(--primary-color);font-size:.85rem;font-weight:400;margin-left:.5rem}.member-role-badge{display:flex;align-items:center;gap:.5rem}.badge{font-size:1rem}.role-text{font-size:.9rem;color:var(--text-secondary);text-transform:capitalize}.member-actions{display:flex;gap:.5rem;align-items:center}.role-select{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;cursor:pointer}.role-select:disabled{opacity:.5;cursor:not-allowed}.remove-btn{width:32px;height:32px;border:none;background:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-btn:hover:not(:disabled){background:#e53e3e1a;color:var(--error-color)}.remove-btn:disabled{opacity:.3;cursor:not-allowed}@media(max-width:768px){.member-row{flex-direction:column;align-items:flex-start;gap:1rem}.member-actions{width:100%;justify-content:flex-end}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.modal{background:var(--card-bg);border-radius:12px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.3rem;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:1.2rem;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s}.close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.modal-body{padding:1.5rem}.search-section{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3182ce1a}.search-btn{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background .2s}.search-btn:hover:not(:disabled){background:var(--primary-hover)}.search-btn:disabled{opacity:.5;cursor:not-allowed}.search-results{margin-top:1rem;max-height:300px;overflow-y:auto}.user-result{display:flex;align-items:center;justify-content:space-between;padding:1rem;border:1px solid var(--border-color);border-radius:4px;margin-bottom:.5rem;transition:all .2s}.user-result:hover{background:var(--hover-bg)}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;text-transform:uppercase}.user-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.user-email{font-size:.85rem;color:var(--text-muted)}.add-btn{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.add-btn:hover{background:var(--primary-hover)}.no-results{text-align:center;color:var(--text-muted);padding:2rem}.member-management{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color)}.member-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.member-header h3{margin:0;color:var(--text-primary);font-size:1.1rem}.add-member-btn{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.add-member-btn:hover{background:var(--primary-hover)}.member-list{display:flex;flex-direction:column;gap:.75rem}.circle-settings{background:var(--card-bg);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);margin-top:1.5rem}.circle-settings h3{margin:0 0 1.5rem;color:var(--text-primary);font-size:1.1rem}.setting-item{margin-bottom:1.5rem}.setting-item label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:500}.display-name{display:flex;align-items:center;gap:1rem}.display-name span{font-size:1rem;color:var(--text-primary)}.display-name button{padding:.25rem .75rem;background:none;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.display-name button:hover{background:var(--hover-bg);color:var(--primary-color);border-color:var(--primary-color)}.edit-name{display:flex;gap:.5rem;align-items:center}.edit-name input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary)}.edit-name input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3182ce1a}.edit-name button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.edit-name button:first-of-type{background:var(--primary-color);color:#fff}.edit-name button:first-of-type:hover:not(:disabled){background:var(--primary-hover)}.edit-name button:last-of-type{background:none;border:1px solid var(--border-color);color:var(--text-secondary)}.edit-name button:last-of-type:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary)}.edit-name button:disabled{opacity:.5;cursor:not-allowed}.circle-page{max-width:1200px;margin:0 auto;padding:2rem}.circle-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:2rem;margin-bottom:2rem;color:#fff;box-shadow:0 4px 6px #0000001a}.circle-header-content{max-width:800px;margin:0 auto}.back-btn{background:#fff3;border:none;color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;margin-bottom:1.5rem;transition:background .2s}.back-btn:hover{background:#ffffff4d}.circle-title-section{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.circle-title-section h1{margin:0;font-size:2.5rem;font-weight:700}.circle-badge{background:#ffffff4d;padding:.25rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.circle-description{font-size:1.1rem;opacity:.9;margin-bottom:2rem;line-height:1.6}.circle-stats{display:flex;gap:2rem;margin-bottom:2rem}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.9rem;opacity:.8}.circle-actions{display:flex;gap:1rem}.circle-tabs{display:flex;gap:1rem;border-bottom:1px solid #eaeaea;margin-bottom:2rem}.tab{padding:1rem 2rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#718096;transition:all .2s}.tab:hover{color:#3182ce}.tab.active{color:#3182ce;border-bottom-color:#3182ce}.posts-section{display:flex;flex-direction:column;gap:1.5rem}.circle-post-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;border:1px solid #eaeaea}.post-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.post-author-avatar{width:40px;height:40px;border-radius:50%;background:#3182ce;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.post-author-info{flex:1}.post-author{font-weight:600;color:#2d3748}.post-date{font-size:.85rem;color:#718096}.post-content h4{margin:0 0 .5rem;color:#2d3748}.post-content p{color:#4a5568;line-height:1.6;margin:0}.post-actions{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #eaeaea}.post-action-btn{background:none;border:none;color:#718096;cursor:pointer;padding:.5rem 1rem;border-radius:20px;transition:background .2s}.post-action-btn:hover{background:#f7fafc;color:#3182ce}.members-section{padding:1rem 0}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.member-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid #eaeaea;border-radius:8px;transition:transform .2s,box-shadow .2s}.member-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.member-avatar{width:48px;height:48px;border-radius:50%;background:#3182ce;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700}.member-info{flex:1}.member-name{font-weight:600;color:#2d3748;margin-bottom:.25rem}.owner-tag{color:#3182ce;font-size:.85rem;font-weight:400;margin-left:.5rem}.member-role{display:flex;align-items:center;gap:.5rem}.member-badge{font-size:1rem}.member-role-text{font-size:.9rem;color:#718096;text-transform:capitalize}.member-joined{font-size:.8rem;color:#a0aec0;margin-top:.25rem}.create-post-section{margin-top:2rem;padding:1.5rem;background:#ffffff1a;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.create-post-section .create-post-form{background:transparent;padding:0}.empty-state{text-align:center;padding:3rem;background:#f7fafc;border-radius:8px;border:2px dashed #e2e8f0}.empty-state p{color:#718096;margin-bottom:1rem}.secondary-btn.danger{color:#e53e3e;border-color:#e53e3e}.secondary-btn.danger:hover{background:#fff5f5}@media(max-width:768px){.circle-page{padding:1rem}.circle-header{padding:1.5rem}.circle-title-section{flex-direction:column;align-items:flex-start;gap:.5rem}.circle-title-section h1{font-size:1.8rem}.circle-stats{flex-wrap:wrap;gap:1rem}.circle-actions{flex-direction:column}.members-grid{grid-template-columns:1fr}.post-actions{flex-wrap:wrap}}.search-header{margin-bottom:2rem}.search-header h1{font-size:1.8rem;color:var(--text-primary);margin-bottom:.5rem}.results-count{color:var(--text-secondary)}.search-tabs{display:flex;gap:1rem;border-bottom:1px solid var(--border-color);margin-bottom:2rem}.tab{padding:1rem 2rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:var(--text-secondary);transition:all .2s}.tab:hover{color:var(--primary-color)}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.user-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .2s,box-shadow .2s}.user-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.user-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;margin-bottom:1rem}.user-info h3{margin:0 0 .25rem;color:var(--text-primary)}.user-info p{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.view-btn{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.view-btn:hover{background:var(--primary-hover)}.navbar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 2rem;background:var(--navbar-bg);border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px #0000000d;position:sticky;top:0;z-index:1000;height:70px;transition:background-color .3s ease,border-color .3s ease}.navbar-logo{font-size:1.5rem;font-weight:700;color:var(--primary-color);cursor:pointer;transition:color .2s}.navbar-logo:hover{color:var(--primary-hover)}.navbar-search{display:flex;align-items:center;position:relative;flex:1;max-width:500px}.search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid var(--border-color);border-radius:25px;font-size:.95rem;transition:all .2s;background:var(--bg-secondary);color:var(--text-primary)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3182ce1a;background:var(--bg-primary)}.search-input::placeholder{color:var(--text-secondary)}.search-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--text-secondary);padding:.5rem;transition:color .2s}.search-btn:hover{color:var(--primary-color)}.navbar-right{display:flex;align-items:center;gap:1rem}.navbar-icon{position:relative;background:none;border:none;cursor:pointer;padding:.5rem;font-size:1.2rem;border-radius:50%;transition:background-color .2s;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.navbar-icon:hover{background-color:var(--hover-bg);color:var(--primary-color)}.badge{position:absolute;top:2px;right:2px;background:#e53e3e;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--navbar-bg)}.navbar-user{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:background-color .2s;position:relative}.navbar-user:hover{background-color:var(--hover-bg)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;text-transform:uppercase}.user-name{font-weight:500;color:var(--text-primary);font-size:.95rem}.dropdown-arrow{font-size:.8rem;color:var(--text-secondary);margin-left:.25rem}.user-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:200px;z-index:1001;overflow:hidden}.dropdown-item{display:block;width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;cursor:pointer;transition:background-color .2s;font-size:.95rem;color:var(--text-primary)}.dropdown-item:hover{background-color:var(--hover-bg);color:var(--primary-color)}.dropdown-item.logout{color:#e53e3e}.dropdown-divider{height:1px;background-color:var(--border-color);margin:.5rem 0}.sidebar{width:260px;background:var(--sidebar-bg);border-right:1px solid var(--border-color);height:calc(100vh - 70px);position:sticky;top:70px;display:flex;flex-direction:column;padding:1.5rem 0;transition:transform .3s ease,background-color .3s ease}.sidebar.mobile{position:fixed;top:0;left:0;height:100vh;z-index:2000;transform:translate(-100%);box-shadow:2px 0 8px #0000001a}.sidebar.mobile.open{transform:translate(0)}.sidebar-header{padding:0 1.5rem 1rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.sidebar-title{font-size:1rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0}.close-btn{background:none;border:none;font-size:1.2rem;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background-color:var(--hover-bg);color:var(--primary-color)}.hamburger-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:2001;width:40px;height:40px;background:var(--primary-color);border:none;border-radius:8px;cursor:pointer;padding:10px;box-shadow:var(--shadow-md)}.hamburger-btn span{display:block;width:20px;height:2px;background:#fff;margin:4px auto;transition:transform .3s ease}.hamburger-btn.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburger-btn.open span:nth-child(2){opacity:0}.hamburger-btn.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:1999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:1rem;width:100%;padding:.75rem 1.5rem;background:none;border:none;cursor:pointer;transition:all .2s;font-size:1rem;color:var(--text-secondary);text-align:left}.sidebar-item:hover{background:var(--hover-bg);color:var(--primary-color)}.sidebar-item.active{background:var(--hover-bg);color:var(--primary-color);font-weight:500;border-left:3px solid var(--primary-color)}.sidebar-icon{font-size:1.2rem;width:24px;text-align:center}.sidebar-label{flex:1}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.user-status{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:#48bb78;box-shadow:0 0 0 2px #48bb7833}.sidebar-hint{font-size:.8rem;color:var(--text-secondary);opacity:.7}@media(max-width:768px){.hamburger-btn{display:block}.sidebar{display:none}.sidebar.mobile{display:flex}.dashboard-content{padding-top:60px}.dashboard-main{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--text-primary: #2d3748;--text-secondary: #4a5568;--text-muted: #718096;--border-color: #eaeaea;--card-bg: #ffffff;--sidebar-bg: #ffffff;--navbar-bg: #ffffff;--hover-bg: #f7fafc;--primary-color: #3182ce;--primary-hover: #2c5282;--success-color: #48bb78;--warning-color: #ecc94b;--error-color: #e53e3e;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}.dark-mode{--bg-primary: #1a202c;--bg-secondary: #2d3748;--text-primary: #f7fafc;--text-secondary: #e2e8f0;--text-muted: #a0aec0;--border-color: #4a5568;--card-bg: #2d3748;--sidebar-bg: #1a202c;--navbar-bg: #1a202c;--hover-bg: #2d3748;--primary-color: #63b3ed;--primary-hover: #4299e1;--success-color: #68d391;--warning-color: #fbbf24;--error-color: #fc8181;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3)}html,body{height:100%;margin:0;padding:0}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:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin-bottom:1rem;font-weight:600;line-height:1.2}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}a{color:var(--primary-color);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover);text-decoration:underline}button{cursor:pointer;font-family:inherit;border:none;background:none;transition:all .2s}.primary-btn{background:var(--primary-color);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;border:none;cursor:pointer;transition:background .2s,transform .1s;box-shadow:var(--shadow-sm)}.primary-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.secondary-btn{background:transparent;color:var(--primary-color);padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.secondary-btn:hover{background:var(--hover-bg);border-color:var(--primary-color)}.link-btn{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;font-size:inherit;padding:0}.link-btn:hover{color:var(--primary-hover)}input,textarea,select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3182ce1a;background:var(--bg-primary)}input::placeholder,textarea::placeholder{color:var(--text-muted)}label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:500}.form-group{margin-bottom:1.5rem}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:all .2s}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.dashboard-content{display:flex;flex:1;background:var(--bg-primary)}.dashboard-main{flex:1;padding:2rem;background:var(--bg-secondary);overflow-y:auto;transition:background-color .3s ease}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card h3{color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.stat-number{font-size:2rem;font-weight:700;color:var(--primary-color);margin:0}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-secondary);font-size:1rem}.loading-spinner:after{content:"";width:2rem;height:2rem;margin-left:1rem;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spinner .6s linear infinite}@keyframes spinner{to{transform:rotate(360deg)}}.error-message{background:#e53e3e1a;color:var(--error-color);padding:1rem;border-radius:8px;margin:1rem 0;border:1px solid var(--error-color)}.empty-state{text-align:center;padding:3rem;background:var(--card-bg);border-radius:12px;border:2px dashed var(--border-color);margin:2rem 0}.empty-state p{color:var(--text-secondary);margin-bottom:1rem}.empty-message{color:var(--text-muted);font-style:italic;padding:1rem;background:var(--card-bg);border-radius:8px;text-align:center;border:1px solid var(--border-color)}.debug-info{margin:2rem 0;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-family:monospace;font-size:.9rem}.debug-info summary{cursor:pointer;color:var(--primary-color);margin-bottom:.5rem}.debug-info pre{margin:0;white-space:pre-wrap;word-wrap:break-word}@media(max-width:1200px){.dashboard-main{padding:1.75rem}.grid-4{grid-template-columns:repeat(3,1fr)}}@media(max-width:1024px){h1{font-size:2.2rem}h2{font-size:1.8rem}.dashboard-main{padding:1.5rem}.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}}@media(max-width:768px){h1{font-size:2rem}h2{font-size:1.6rem}h3{font-size:1.4rem}.dashboard-content{flex-direction:column}.dashboard-main{padding:1.25rem}.grid-2,.grid-3,.grid-4,.stats-grid{grid-template-columns:1fr}.card{padding:1.25rem}.primary-btn,.secondary-btn{width:100%;padding:.6rem 1.2rem}}@media(max-width:480px){h1{font-size:1.75rem}h2{font-size:1.4rem}.dashboard-main,.stat-card{padding:1rem}.stat-number{font-size:1.5rem}.empty-state{padding:2rem 1rem}}@media print{.navbar,.sidebar,.no-print{display:none!important}.dashboard-main{padding:0;background:#fff}body{background:#fff;color:#000}}
