body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0f0f0f;color:#e5e5e5}#root{height:100vh;width:100vw}.auth-form{max-width:400px;margin:0 auto;padding:32px;background:#1a1a1a;border-radius:12px;border:1px solid #2a2a2a}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:28px;font-weight:600;color:#e5e5e5;margin-bottom:8px}.auth-header p{color:#9ca3af;font-size:14px}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:6px;margin-bottom:24px;font-size:14px}.form-group input{width:100%;background:#2a2a2a;border:1px solid #374151;color:#e5e5e5;padding:12px 16px;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}.form-group input:focus{border-color:#3b82f6}.slug-input{display:flex;align-items:center;background:#2a2a2a;border:1px solid #374151;border-radius:6px;overflow:hidden;transition:border-color .2s}.slug-input:focus-within{border-color:#3b82f6}.slug-prefix{padding:12px 16px;background:#1a1a1a;color:#9ca3af;font-size:14px;border-right:1px solid #374151;white-space:nowrap}.slug-input input{border:none;background:transparent;padding:12px 16px;flex:1;min-width:0}.slug-input input:focus{border:none;outline:none}.auth-button{width:100%;background:#3b82f6;color:#fff;border:none;padding:12px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;margin-top:8px}.auth-button:hover:not(:disabled){background:#2563eb}.auth-button:disabled{background:#374151;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #2a2a2a}.auth-footer p{color:#9ca3af;font-size:14px}.auth-link{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:14px;text-decoration:underline;padding:0}.auth-link:hover{color:#2563eb}@media (max-width: 768px){.auth-form{max-width:100%;margin:16px;padding:24px}.form-row{grid-template-columns:1fr;gap:0}.slug-prefix{font-size:12px;padding:12px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);padding:20px}.auth-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:500px}.auth-branding{text-align:center;margin-bottom:40px}.auth-logo{font-size:48px;font-weight:700;color:#e5e5e5;margin-bottom:12px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-tagline{color:#9ca3af;font-size:16px;max-width:400px}.auth-content{width:100%}@media (max-width: 768px){.auth-page{padding:16px}.auth-logo{font-size:36px}.auth-tagline{font-size:14px}.auth-branding{margin-bottom:32px}}.project-list{flex:1;display:flex;flex-direction:column;overflow:hidden}.project-list-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px}.project-list-header h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af}.create-project-form{padding:0 20px 16px}.create-project-form input{width:100%;background:#0f0f0f;border:1px solid #2a2a2a;color:#e5e5e5;padding:8px 12px;border-radius:6px;font-size:14px;margin-bottom:8px}.create-project-form input:focus{outline:none;border-color:#3b82f6}.form-actions{display:flex;gap:8px}.projects{flex:1;overflow-y:auto;padding:0 12px}.project-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .2s;font-size:14px;margin-bottom:4px}.project-item:hover{background:#2a2a2a}.project-item.active{background:#2a2a2a;font-weight:500}.project-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.task-card{background:#0f0f0f;border:1px solid #2a2a2a;border-left:3px solid;border-radius:6px;padding:12px;cursor:grab;transition:all .2s;-webkit-user-select:none;user-select:none}.task-card:active{cursor:grabbing}.task-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a;transform:translateY(-2px)}.task-card.highlighted{border:2px solid #3b82f6!important;box-shadow:0 0 0 3px #3b82f633,0 4px 12px #3b82f64d;animation:highlight-pulse 2s ease-in-out}@keyframes highlight-pulse{0%,to{box-shadow:0 0 0 3px #3b82f633,0 4px 12px #3b82f64d}50%{box-shadow:0 0 0 6px #3b82f64d,0 4px 16px #3b82f680}}.task-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.task-title{font-size:14px;font-weight:500;line-height:1.4;flex:1}.task-priority{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;background:#6b72801a}.task-description{font-size:12px;color:#9ca3af;line-height:1.5;margin-bottom:8px}.task-labels{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.task-label{font-size:11px;padding:2px 8px;border-radius:4px;color:#fff;font-weight:500}.task-due-date{display:flex;align-items:center;gap:4px;margin-bottom:8px;font-size:11px;color:#9ca3af;padding:2px 6px;background:#6b72801a;border-radius:4px;width:fit-content}.task-due-date.overdue{color:#ef4444;background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.due-date-icon{font-size:10px}.due-date-text{font-weight:500}.task-due-date .overdue-indicator{font-size:9px}.task-subtasks{margin-top:12px;padding-top:12px;border-top:1px solid #2a2a2a;font-size:12px}.task-subtasks ul{margin-top:8px;padding-left:20px}.task-subtasks li{margin-bottom:4px;color:#9ca3af}.subtask-badge{display:inline-block;font-size:10px;padding:2px 6px;background:#2a2a2a;color:#9ca3af;border-radius:4px;margin-top:8px}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:24px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-content h2{font-size:20px;margin-bottom:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:600;color:#9ca3af;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group textarea,.form-group select{width:100%;background:#0f0f0f;border:1px solid #2a2a2a;color:#e5e5e5;padding:10px 12px;border-radius:6px;font-size:14px;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.label-selector{display:flex;flex-wrap:wrap;gap:8px}.label-option{padding:6px 12px;border-radius:6px;font-size:13px;border:2px solid;cursor:pointer;transition:all .2s;font-weight:500}.label-option.selected{color:#fff}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #2a2a2a}.task-board{height:100%}.board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}.board-title-section{display:flex;align-items:center;gap:16px}.board-header h2{font-size:28px;font-weight:600;margin:0}.overdue-indicator{display:flex;align-items:center;gap:6px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;padding:6px 12px;color:#ef4444;font-size:14px;font-weight:500}.overdue-icon{font-size:14px}.overdue-text{white-space:nowrap}.board-controls{display:flex;align-items:center;gap:12px}.board-filters{display:flex;gap:8px}.filter-select,.sort-select{background:#2a2a2a;border:1px solid #374151;color:#e5e5e5;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;outline:none;min-width:140px}.filter-select:focus,.sort-select:focus{border-color:#3b82f6}.filter-select option,.sort-select option{background:#2a2a2a;color:#e5e5e5}.board-columns{display:flex;gap:16px;overflow-x:auto;padding-bottom:20px}.board-column{flex:0 0 300px;background:#1a1a1a;border-radius:8px;padding:16px;max-height:calc(100vh - 200px);display:flex;flex-direction:column;transition:background-color .2s}.board-column.drag-over{background:#252525;border:2px dashed #3b82f6}.column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #2a2a2a}.column-header h3{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af}.task-count{background:#2a2a2a;color:#9ca3af;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.column-tasks{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;min-height:100px}.task-card.dragging{cursor:grabbing;box-shadow:0 8px 24px #00000080;transform:rotate(3deg);background:#1a1a1a;border:1px solid #3b82f6}.calendar-view{flex:1;padding:24px;display:flex;flex-direction:column;height:100%;overflow:hidden}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.calendar-nav{display:flex;align-items:center;gap:16px}.calendar-nav-btn{background:#2a2a2a;border:1px solid #374151;color:#e5e5e5;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:16px;transition:all .2s}.calendar-nav-btn:hover{background:#374151;border-color:#3b82f6}.calendar-title{font-size:24px;font-weight:600;color:#e5e5e5;margin:0;min-width:200px;text-align:center}.calendar-today-btn{background:#3b82f6;border:none;color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.calendar-today-btn:hover{background:#2563eb}.calendar-overdue-section{background:#1a0f0f;border:1px solid #3f1515;border-radius:8px;padding:16px;margin-bottom:24px}.calendar-overdue-section h3{color:#ef4444;font-size:16px;font-weight:600;margin:0 0 12px;display:flex;align-items:center;gap:8px}.calendar-overdue-tasks{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.calendar-overdue-task{max-width:100%}.calendar-grid{flex:1;display:flex;flex-direction:column;border:1px solid #2a2a2a;border-radius:8px;overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:#1a1a1a;border-bottom:1px solid #2a2a2a}.calendar-weekday{padding:12px 8px;text-align:center;font-size:12px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,1fr);flex:1}.calendar-day{border-right:1px solid #2a2a2a;border-bottom:1px solid #2a2a2a;padding:8px;min-height:120px;display:flex;flex-direction:column;background:#0f0f0f;transition:background .2s}.calendar-day:hover{background:#1a1a1a}.calendar-day.other-month{background:#0a0a0a;opacity:.5}.calendar-day.today{background:#1a1a2e;border:2px solid #3b82f6}.calendar-day:nth-child(7n){border-right:none}.calendar-day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.calendar-day-number{font-size:14px;font-weight:600;color:#e5e5e5}.calendar-day.other-month .calendar-day-number{color:#6b7280}.calendar-day.today .calendar-day-number{color:#3b82f6}.calendar-day-count{background:#3b82f6;color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.calendar-day-tasks{flex:1;display:flex;flex-direction:column;gap:2px}.calendar-task{display:flex;align-items:center;gap:6px;padding:2px 4px;background:#2a2a2a;border-radius:3px;cursor:pointer;transition:all .2s;min-height:20px}.calendar-task:hover{background:#374151;transform:translate(2px)}.calendar-task-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.calendar-task-title{font-size:11px;color:#e5e5e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.calendar-task-more{font-size:10px;color:#9ca3af;text-align:center;padding:2px;font-style:italic}.calendar-loading{display:flex;align-items:center;justify-content:center;height:400px;color:#9ca3af;font-size:16px}@media (max-width: 768px){.calendar-view{padding:16px}.calendar-day{min-height:80px;padding:4px}.calendar-task{padding:1px 2px}.calendar-task-title{font-size:10px}.calendar-overdue-tasks{grid-template-columns:1fr}}.command-palette-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:20vh;z-index:9999;animation:fadeIn .15s ease-out}.command-palette{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:90%;max-width:640px;max-height:60vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideDown .2s ease-out}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.command-palette-input-wrapper{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #2a2a2a;gap:12px}.command-palette-icon{font-size:20px;opacity:.5}.command-palette-input{flex:1;background:transparent;border:none;color:#e5e5e5;font-size:16px;outline:none}.command-palette-input::placeholder{color:#666}.command-palette-kbd{background:#2a2a2a;color:#9ca3af;padding:4px 8px;border-radius:4px;font-size:11px;font-family:monospace;font-weight:600}.command-palette-results{flex:1;overflow-y:auto;padding:8px}.command-palette-section{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#666;margin-top:8px}.command-palette-section:first-child{margin-top:0}.command-palette-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:all .15s;margin-bottom:2px}.command-palette-item:hover,.command-palette-item.selected{background:#2a2a2a}.command-palette-item.selected{background:#3b82f6}.command-palette-item-icon{font-size:18px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:4px}.command-palette-item-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.command-palette-item-title{font-size:14px;font-weight:500;color:#e5e5e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.command-palette-item.selected .command-palette-item-title{color:#fff}.command-palette-item-meta{font-size:12px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.command-palette-item.selected .command-palette-item-meta{color:#fffc}.command-palette-empty{padding:40px 20px;text-align:center;color:#666;font-size:14px}.command-palette-footer{padding:12px 20px;border-top:1px solid #2a2a2a;display:flex;justify-content:space-between;align-items:center}.command-palette-hint{display:flex;gap:12px;font-size:12px;color:#9ca3af;align-items:center}.command-palette-hint kbd{background:#2a2a2a;padding:2px 6px;border-radius:3px;font-size:11px;font-family:monospace;margin-right:4px}.task-detail-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .15s ease-out}.task-detail-modal{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .2s ease-out;overflow:hidden}.task-detail-header{padding:24px 24px 16px;border-bottom:1px solid #2a2a2a}.task-detail-title-section{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.task-detail-title{font-size:24px;font-weight:600;color:#e5e5e5;margin:0;flex:1;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s;min-height:32px;line-height:1.2}.task-detail-title:hover{background:#2a2a2a}.task-detail-title-input{font-size:24px;font-weight:600;color:#e5e5e5;background:#2a2a2a;border:2px solid #3b82f6;border-radius:4px;padding:4px 8px;flex:1;outline:none;font-family:inherit}.task-detail-close{background:transparent;border:none;color:#9ca3af;font-size:20px;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.task-detail-close:hover{background:#2a2a2a;color:#e5e5e5}.task-detail-meta{display:flex;align-items:center;gap:12px}.task-detail-id{font-size:14px;color:#9ca3af;font-family:monospace}.task-detail-subtask-badge{background:#2a2a2a;color:#9ca3af;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.task-detail-content{display:flex;flex:1;overflow:hidden}.task-detail-main{flex:1;padding:24px;overflow-y:auto}.task-detail-sidebar{width:280px;background:#0f0f0f;border-left:1px solid #2a2a2a;padding:24px;overflow-y:auto}.task-detail-section{margin-bottom:32px}.task-detail-section:last-child{margin-bottom:0}.task-detail-section h3{font-size:16px;font-weight:600;color:#e5e5e5;margin:0 0 16px}.task-detail-description{color:#d1d5db;line-height:1.6;cursor:pointer;padding:12px;border-radius:6px;border:1px solid transparent;transition:all .2s;min-height:60px}.task-detail-description:hover{background:#2a2a2a;border-color:#374151}.task-detail-description-input{width:100%;background:#2a2a2a;border:2px solid #3b82f6;color:#e5e5e5;padding:12px;border-radius:6px;font-size:14px;line-height:1.6;resize:vertical;outline:none;font-family:inherit}.task-detail-placeholder{color:#6b7280;font-style:italic}.task-detail-subtasks{display:flex;flex-direction:column;gap:8px}.task-detail-subtask{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#2a2a2a;border-radius:6px;border-left:3px solid #3b82f6}.subtask-title{color:#e5e5e5;font-size:14px}.subtask-status{color:#9ca3af;font-size:12px;text-transform:capitalize}.task-detail-comments{display:flex;flex-direction:column;gap:12px}.task-detail-comment-placeholder{color:#6b7280;font-style:italic;text-align:center;padding:20px}.task-detail-property{margin-bottom:20px;position:relative}.task-detail-property label{display:block;font-size:12px;font-weight:600;color:#9ca3af;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.task-detail-select{width:100%;background:#2a2a2a;border:1px solid #374151;color:#e5e5e5;padding:8px 12px;border-radius:6px;font-size:14px;cursor:pointer;outline:none}.task-detail-select:focus{border-color:#3b82f6}.task-detail-priority-indicator{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;margin-top:10px}.task-detail-labels{display:flex;flex-wrap:wrap;gap:6px}.task-detail-label{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;border:1px solid;cursor:pointer;transition:all .2s;background:transparent}.task-detail-label:hover{opacity:.8}.task-detail-date{color:#d1d5db;font-size:14px}.task-detail-due-date{display:flex;flex-direction:column;gap:8px}.task-detail-date-input{width:100%;background:#2a2a2a;border:1px solid #374151;color:#e5e5e5;padding:8px 12px;border-radius:6px;font-size:14px;cursor:pointer;outline:none}.task-detail-date-input:focus{border-color:#3b82f6}.task-detail-due-date-display{font-size:12px;color:#9ca3af;display:flex;align-items:center;gap:4px}.task-detail-due-date-display.overdue{color:#ef4444;font-weight:500}.overdue-indicator{font-size:10px}.task-detail-footer{padding:16px 24px;border-top:1px solid #2a2a2a;background:#0f0f0f}.task-detail-shortcuts{display:flex;gap:16px;font-size:12px;color:#9ca3af;align-items:center}.task-detail-shortcuts kbd{background:#2a2a2a;padding:2px 6px;border-radius:3px;font-size:11px;font-family:monospace;margin-right:4px}.task-detail-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:#9ca3af;font-size:16px}.invite-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .15s ease-out}.invite-modal{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:90%;max-width:500px;box-shadow:0 20px 60px #00000080;animation:slideUp .2s ease-out}.invite-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0}.invite-modal-header h2{font-size:20px;font-weight:600;color:#e5e5e5;margin:0}.invite-modal-content{padding:24px}.invite-description{color:#9ca3af;font-size:14px;line-height:1.5;margin-bottom:24px}.invite-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#e5e5e5;margin-bottom:6px}.form-group input,.form-group select{width:100%;background:#2a2a2a;border:1px solid #374151;color:#e5e5e5;padding:12px 16px;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6}.form-group input::placeholder{color:#6b7280}.role-description{margin-top:6px;font-size:12px;color:#6b7280;line-height:1.4}.invite-modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #2a2a2a}@media (max-width: 768px){.invite-modal{width:95%;margin:16px}.invite-modal-header{padding:20px 20px 0}.invite-modal-content{padding:20px}.invite-modal-actions{flex-direction:column-reverse}.invite-modal-actions button{width:100%}}.user-role-menu{position:relative}.role-trigger{display:flex;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;padding:0;font-size:12px}.role-trigger.disabled{cursor:default}.role-badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-owner{background:#7c3aed;color:#fff}.role-admin{background:#dc2626;color:#fff}.role-member{background:#374151;color:#d1d5db}.dropdown-arrow{font-size:8px;color:#9ca3af;transition:transform .2s}.role-trigger:hover .dropdown-arrow{transform:translateY(-1px)}.role-menu-overlay{position:fixed;inset:0;z-index:999}.role-dropdown{position:absolute;top:100%;right:0;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:4px 0;margin-top:4px;box-shadow:0 10px 25px #00000080;z-index:1000;min-width:200px}.role-option{width:100%;background:transparent;border:none;color:#e5e5e5;padding:8px 12px;text-align:left;cursor:pointer;font-size:14px;transition:background .2s;display:flex;align-items:center;justify-content:space-between}.role-option:hover{background:#2a2a2a}.role-option.current{background:#3b82f61a}.role-option-content{display:flex;flex-direction:column;gap:2px}.role-description{font-size:11px;color:#9ca3af;font-weight:400}.current-indicator{color:#3b82f6;font-size:12px;font-weight:700}.user-management-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .15s ease-out}.user-management-modal{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .2s ease-out;overflow:hidden}.user-management-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #2a2a2a}.user-management-header h2{font-size:24px;font-weight:600;color:#e5e5e5;margin:0}.header-actions{display:flex;align-items:center;gap:12px}.user-management-content{flex:1;overflow-y:auto;padding:24px}.user-section{margin-bottom:32px}.user-section:last-child{margin-bottom:0}.user-section h3{font-size:16px;font-weight:600;color:#e5e5e5;margin:0 0 16px;display:flex;align-items:center;gap:8px}.user-list,.invitation-list{display:flex;flex-direction:column;gap:12px}.user-item,.invitation-item{display:flex;align-items:center;gap:16px;padding:16px;background:#2a2a2a;border-radius:8px;border:1px solid #374151}.user-avatar,.invitation-avatar{width:48px;height:48px;border-radius:50%;background:#3b82f6;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-initials{color:#fff;font-size:16px;font-weight:600}.invitation-icon{font-size:20px}.user-info,.invitation-info{flex:1;min-width:0}.user-name,.invitation-email{font-size:16px;font-weight:500;color:#e5e5e5;margin-bottom:4px;display:flex;align-items:center;gap:8px}.you-badge{background:#3b82f6;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.user-email{font-size:14px;color:#9ca3af;margin-bottom:4px}.user-meta,.invitation-meta{font-size:12px;color:#6b7280;line-height:1.4}.user-actions,.invitation-actions{display:flex;align-items:center;gap:8px}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state p{margin:0;font-size:14px}.loading{text-align:center;padding:20px;color:#9ca3af;font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.user-management-modal{width:95%;max-height:90vh}.user-management-header,.user-management-content{padding:20px}.user-item,.invitation-item{flex-direction:column;align-items:flex-start;gap:12px}.user-actions,.invitation-actions{width:100%;justify-content:flex-end}}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:12px;background:transparent;border:1px solid #2a2a2a;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s;color:#e5e5e5;width:100%}.user-menu-trigger:hover{background:#2a2a2a;border-color:#374151}.user-avatar{width:32px;height:32px;border-radius:50%;background:#3b82f6;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-initials{color:#fff;font-size:12px;font-weight:600}.user-info{flex:1;text-align:left;min-width:0}.user-name{font-size:14px;font-weight:500;color:#e5e5e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-org{font-size:12px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-arrow{font-size:10px;color:#9ca3af;transition:transform .2s}.user-menu-trigger:hover .dropdown-arrow{transform:translateY(-1px)}.user-menu-overlay{position:fixed;inset:0;z-index:999}.user-menu-dropdown{position:absolute;bottom:100%;left:0;right:0;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:8px 0;margin-bottom:8px;box-shadow:0 10px 25px #00000080;z-index:1000;max-height:400px;overflow-y:auto}.user-menu-header{padding:12px 16px;border-bottom:1px solid #2a2a2a;margin-bottom:8px}.user-email{font-size:14px;color:#e5e5e5;margin-bottom:4px}.user-role-badge{display:inline-block;background:#2a2a2a;color:#9ca3af;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.user-menu-section{padding:4px 0}.user-menu-section:not(:last-child){border-bottom:1px solid #2a2a2a;margin-bottom:4px;padding-bottom:8px}.user-menu-item{width:100%;background:transparent;border:none;color:#e5e5e5;padding:8px 16px;text-align:left;cursor:pointer;font-size:14px;transition:background .2s;display:flex;align-items:center;gap:12px}.user-menu-item:hover{background:#2a2a2a}.user-menu-item.logout{color:#ef4444}.user-menu-item.logout:hover{background:#ef44441a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#0f0f0f;color:#e5e5e5}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;background:#1a1a1a;border-right:1px solid #2a2a2a;display:flex;flex-direction:column}.app-header{padding:24px 20px;border-bottom:1px solid #2a2a2a}.app-title-section{margin-bottom:12px}.app-header h1{font-size:24px;margin-bottom:12px}.view-switcher{display:flex;background:#2a2a2a;border-radius:6px;padding:2px}.view-btn{flex:1;background:transparent;border:none;color:#9ca3af;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s}.view-btn.active{background:#3b82f6;color:#fff}.view-btn:hover:not(.active){background:#374151;color:#d1d5db}.shortcuts-hint{font-size:11px;color:#666}.main-content{flex:1;overflow-y:auto;padding:24px}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:#666}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{background:#374151;cursor:not-allowed}.btn-secondary{background:transparent;color:#9ca3af;border:1px solid #374151;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-secondary:hover{border-color:#4b5563;color:#d1d5db}.btn-icon{background:transparent;border:none;color:#9ca3af;font-size:20px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-icon:hover{background:#2a2a2a;color:#e5e5e5}.btn-sm{padding:4px 12px;font-size:12px}.loading-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:#0f0f0f}.loading-spinner{text-align:center}.spinner{width:40px;height:40px;border:3px solid #2a2a2a;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner p{color:#9ca3af;font-size:14px}
