body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0;padding:0;background:#f5f5f5}.app{display:flex;flex-direction:column;min-height:100vh}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #00000026;width:100%;max-width:400px}.login-box h1{text-align:center;color:#2c3e50;margin-top:0;font-size:1.8rem}.form-group{margin-bottom:1.2rem}.form-group label{display:block;margin-bottom:.5rem;color:#2c3e50;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #bdc3c7;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#ecf0f1;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c33}.login-hint{text-align:center;font-size:.85rem;color:#7f8c8d;margin-top:1rem}header{background:#2c3e50;color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center}header h1{margin:0;font-size:1.8rem}.header-right{display:flex;gap:1rem;align-items:center}.header-right span{font-size:.9rem}.notification-bell{position:relative;background:#34495e;color:#fff;border:none;border-radius:999px;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.notification-bell:hover{background:#2b3b4f}.notification-icon{font-size:1.1rem;display:inline-flex;align-items:center;justify-content:center}.notification-count{position:absolute;top:-4px;right:-4px;background:#e74c3c;color:#fff;border-radius:999px;min-width:18px;height:18px;padding:0 4px;font-size:.7rem;display:inline-flex;align-items:center;justify-content:center;border:2px solid #2c3e50}header button{background:#3498db;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}header button:hover{background:#2980b9}.banner{max-width:1200px;margin:10px auto 0;padding:10px 14px;border-radius:6px;display:flex;justify-content:space-between;align-items:center;gap:12px}.banner-success{background:#ecfdf3;color:#166534;border:1px solid #bbf7d0}.banner-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.banner-warning{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}.banner-actions{display:flex;gap:8px}.notifications-bar{max-width:1200px;margin:10px auto 0;padding:10px 14px;border-radius:6px;border:1px solid #e2e8f0;background:#f8fafc;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.notifications-title{font-weight:600;color:#334155}.notifications-list{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.notification-item{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e2e8f0;padding:6px 10px;border-radius:4px}.notification-empty{color:#64748b;font-size:.9rem}.btn-primary{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.btn-primary:hover{background:#5568d3}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.btn-secondary{background:#64748b;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-secondary:hover{background:#475569}.btn-action{background:#27ae60;color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s}.btn-action:hover{background:#229954}.btn-danger{background:#e74c3c;color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s}.tabs{display:flex;gap:0;border-bottom:2px solid #bdc3c7;background:#fff;padding:0 1rem;overflow-x:auto}.tabs button{background:none;border:none;padding:1rem;cursor:pointer;font-size:.95rem;color:#7f8c8d;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap}.tabs button:hover{color:#2c3e50}.tabs button.active{color:#3498db;border-bottom-color:#3498db}main{flex:1;padding:1.5rem;background:#fff;margin:1rem;border-radius:4px;box-shadow:0 2px 4px #0000000d}section h2{margin-top:0;color:#2c3e50;border-bottom:1px solid #ecf0f1;padding-bottom:.5rem}table{width:100%;border-collapse:collapse}table thead{background:#ecf0f1}table th{padding:.75rem;text-align:left;font-weight:600;color:#2c3e50}table td{padding:.75rem;border-bottom:1px solid #ecf0f1}table tbody tr{transition:background .15s}table tbody tr:hover{background:#f9f9f9}table tbody tr.reversed{opacity:.6;background:#f0f0f0}table tbody tr.expired{opacity:.5;background:#f0f0f0}.audit-table{border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.audit-row{cursor:pointer}.audit-row:hover{background:#f8fafc}.btn-action{background:#e74c3c;color:#fff;border:none;padding:.4rem .8rem;border-radius:3px;cursor:pointer;font-size:.85rem;transition:background .2s}.btn-action:hover{background:#c0392b}.btn-danger{background:#e74c3c;color:#fff;border:none;padding:.4rem .8rem;border-radius:3px;cursor:pointer;font-size:.85rem;transition:background .2s}.btn-danger:hover{background:#c0392b}p{color:#7f8c8d;font-style:italic}p.info{background:#e8f4fd;color:#2c3e50;padding:.75rem;border-radius:4px;border-left:4px solid #3498db;font-style:normal}.moderator-panel{background:#f9fbff;border:1px solid #dfe7f3;border-radius:8px;padding:16px}.moderator-toggle{display:flex;gap:8px;flex-wrap:wrap}.moderator-field{display:flex;flex-direction:column;gap:6px;min-width:180px}.moderator-hint{font-size:.8rem;color:#6b7280}select{padding:.5rem;border:1px solid #bdc3c7;border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer}select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}input[type=text]{padding:.5rem;border:1px solid #bdc3c7;border-radius:4px;font-size:.9rem}input[type=text]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}@media (max-width: 900px){header{flex-direction:column;align-items:flex-start;gap:.75rem}.header-right{flex-wrap:wrap;gap:.5rem}main{margin:.75rem;padding:1rem}}@media (max-width: 720px){header h1{font-size:1.4rem}.tabs{padding:0 .5rem}.tabs button{padding:.75rem;font-size:.85rem}}@media (max-width: 640px){.login-box{margin:0 1rem;padding:1.5rem}main{margin:.5rem;padding:.75rem}table{display:block;overflow-x:auto;white-space:nowrap}}.kanban-container{padding:20px;max-width:1400px;margin:0 auto}.kanban-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.kanban-header h1{margin:0;font-size:28px;color:#1f2937}.kanban-controls{display:flex;gap:10px;align-items:center}.board-selector{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.btn-primary{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#6b7280;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#4b5563}.kanban-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;align-items:start}.kanban-lane{background:#f3f4f6;border-radius:8px;padding:16px;min-height:500px}.lane-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #d1d5db}.lane-header h3{margin:0;font-size:16px;font-weight:600;color:#374151}.card-count{background:#9ca3af;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.lane-cards{display:flex;flex-direction:column;gap:12px}.kanban-card{background:#fff;border-radius:6px;padding:12px;box-shadow:0 1px 3px #0000001a;cursor:grab;transition:transform .2s,box-shadow .2s;position:relative}.kanban-card.archived{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left:4px solid #60a5fa}.kanban-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.kanban-card:active{cursor:grabbing}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.task-id{font-size:12px;font-weight:600;color:#6b7280}.priority-dot{width:12px;height:12px;border-radius:50%}.card-parent-ref{font-size:11px;color:#3b82f6;background:#eff6ff;padding:2px 6px;border-radius:4px;margin-bottom:6px;display:inline-block}.card-title{font-size:14px;font-weight:500;color:#1f2937;margin-bottom:8px;line-height:1.4}.card-assignee{font-size:12px;color:#6b7280;margin-top:8px}.card-due{font-size:12px;margin-top:6px;padding:3px 6px;border-radius:6px;display:inline-block;font-weight:600}.card-due.ok{background:#ecfeff;color:#0e7490}.card-due.soon{background:#fef3c7;color:#92400e}.card-due.overdue{background:#fee2e2;color:#b91c1c}.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.tag-mini{background:#e5e7eb;color:#374151;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:24px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto}.modal-content h2{margin-top:0;margin-bottom:16px;font-size:20px;color:#1f2937}.input-field,.textarea-field,.select-field{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-bottom:12px;font-family:inherit}.textarea-field{resize:vertical}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.card-details h3{margin:8px 0 12px;font-size:18px;color:#1f2937}.parent-todo-info{background:#eff6ff;border-left:4px solid #3b82f6;padding:12px;margin:12px 0;border-radius:6px}.parent-todo-badge{font-size:14px;color:#1e40af;margin-bottom:8px}.kb-sequence{font-size:13px;color:#6b7280}.priority-badge{display:inline-block;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;margin-bottom:12px}.card-description{color:#4b5563;font-size:14px;line-height:1.6;margin:12px 0}.card-meta{background:#f9fafb;padding:12px;border-radius:6px;margin:12px 0;font-size:14px}.card-meta>div{margin:6px 0;color:#6b7280}.card-meta strong{color:#1f2937}.card-due-editor{display:flex;flex-direction:column;gap:8px;margin:12px 0}.card-due-editor label{font-size:14px;font-weight:600;color:#374151}.tag{display:inline-block;background:#dbeafe;color:#1e40af;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;margin-right:6px;margin-top:4px}.kanban-loading,.kanban-error{padding:40px;text-align:center;font-size:16px;color:#6b7280}.kanban-error{color:#ef4444}.board-settings{max-width:600px;max-height:80vh;overflow-y:auto}.settings-section{margin-bottom:24px;padding:16px;background:#f9fafb;border-radius:8px}.settings-section h3{margin:0 0 16px;font-size:18px;color:#374151}.items-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.item-row{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fff;border-radius:6px;border:1px solid #e5e7eb}.item-row span{font-weight:500;color:#374151}.btn-danger-sm{background:#ef4444;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:13px;cursor:pointer;transition:background .2s}.btn-danger-sm:hover{background:#dc2626}.add-item-form{display:flex;gap:8px}.add-item-form .input-field{flex:1;margin:0}@media (max-width: 900px){.kanban-container{padding:16px}.kanban-header{flex-direction:column;align-items:flex-start;gap:12px}.kanban-controls{flex-wrap:wrap}.kanban-board{grid-template-columns:1fr}}@media (max-width: 640px){.kanban-header h1{font-size:22px}.modal-content{width:95%;padding:16px}.modal-actions{flex-direction:column;align-items:stretch}.item-row{flex-direction:column;align-items:flex-start;gap:8px}.add-item-form{flex-direction:column}}.todo-container{padding:20px;max-width:1200px;margin:0 auto}.todo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.todo-header h1{margin:0;font-size:28px;color:#1f2937}.todo-controls{display:flex;gap:10px;align-items:center}.filter-selector{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.filter-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;min-width:220px}.filter-input:focus{outline:none;border-color:#3b82f6}.todo-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:12px;color:#fff;text-align:center;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #11182726}.stat-card.active{box-shadow:0 0 0 2px #1d4ed8}.stat-number{font-size:36px;font-weight:700;margin-bottom:8px}.stat-label{font-size:14px;opacity:.9}.todo-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.todo-item{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s}.todo-item:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.todo-item.completed{opacity:.7;background:#f9fafb}.todo-item.in-progress{border-left:4px solid #3b82f6}.todo-item.archived{border-left:4px solid #60a5fa;background:linear-gradient(135deg,#eff6ff,#dbeafe);position:relative}.todo-item.future{border-left:4px solid #a78bfa;background:linear-gradient(135deg,#faf5ff,#f3e8ff);opacity:.85;position:relative}.archived-badge{position:absolute;top:8px;right:8px;background:#3b82f6;color:#fff;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px}.future-badge{position:absolute;top:8px;right:8px;background:#8b5cf6;color:#fff;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px}.todo-item-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.todo-status-icon{font-size:20px}.todo-taskid{font-weight:600;color:#6b7280;font-size:13px}.todo-priority-indicator{width:12px;height:12px;border-radius:50%;margin-left:auto}.todo-item-title{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:8px;line-height:1.4}.todo-item-description{font-size:14px;color:#6b7280;line-height:1.5}.todo-recurring{display:inline-block;margin-top:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:#2563eb;background:#dbeafe;padding:3px 8px;border-radius:999px}.todo-due{font-size:12px;margin-top:8px;padding:4px 8px;border-radius:6px;display:inline-block;font-weight:600}.todo-due.ok{background:#ecfeff;color:#0e7490}.todo-due.soon{background:#fef3c7;color:#92400e}.todo-due.overdue{background:#fee2e2;color:#b91c1c}.todo-empty{text-align:center;padding:60px 20px;color:#9ca3af;font-size:16px}.todo-loading,.todo-error{padding:40px;text-align:center;font-size:16px;color:#6b7280}.todo-error{color:#ef4444}.todo-details{max-width:600px}.todo-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.todo-detail-header h2{margin:0;font-size:18px;color:#6b7280}.todo-details h3{margin:0 0 12px;font-size:22px;color:#1f2937}.todo-description{color:#4b5563;line-height:1.6;margin:16px 0;white-space:pre-wrap}.todo-meta{display:flex;flex-direction:column;gap:8px;margin:20px 0;padding:16px;background:#f9fafb;border-radius:6px}.todo-meta div{color:#6b7280;font-size:14px}.todo-meta strong{color:#1f2937}.todo-actions{display:flex;gap:12px;margin-top:20px}.todo-actions .select-field{flex:1;margin:0}.btn-danger{background:#ef4444;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.priority-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;color:#fff;text-transform:uppercase;margin-bottom:12px}.notes-section{margin:24px 0;padding:16px;background:#f9fafb;border-radius:8px}.notes-section h4{margin:0 0 12px;font-size:16px;color:#1f2937}.notes-list{margin-bottom:16px}.note-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px;margin-bottom:8px}.note-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px;color:#6b7280;flex-wrap:wrap}.note-author{font-weight:600;color:#3b82f6}.note-date{font-size:11px}.note-source{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;margin-left:auto}.note-source-todo{background:#dbeafe;color:#1e40af}.note-source-kanban{background:#d1fae5;color:#065f46}.note-delete-btn{background:none;border:none;color:#ef4444;cursor:pointer;font-size:16px;padding:0 4px;line-height:1}.note-delete-btn:hover{color:#dc2626}.note-content{color:#374151;font-size:14px;line-height:1.5;white-space:pre-wrap}.no-notes{color:#9ca3af;font-size:14px;font-style:italic;margin:0}.add-note-form{display:flex;flex-direction:column;gap:8px}.note-textarea{width:100%;padding:8px;border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:14px;resize:vertical}.note-textarea:focus{outline:none;border-color:#3b82f6}.testing-section{margin:24px 0;padding:16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.testing-section h4{margin:0 0 12px;font-size:16px;color:#1f2937}.testing-list{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.testing-item{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px 12px}.testing-item.completed{opacity:.7;background:#f1f5f9}.testing-label{display:flex;align-items:center;gap:8px;color:#374151;font-size:14px}.testing-label input{width:16px;height:16px}.testing-delete{background:none;border:none;color:#ef4444;cursor:pointer;font-size:16px;padding:0 4px;line-height:1}.testing-delete:hover{color:#dc2626}.testing-add{display:flex;gap:8px}.testing-add .input-field{flex:1;margin:0}.no-testing{color:#9ca3af;font-size:14px;font-style:italic;margin:0 0 12px}.kanban-section{margin:24px 0;padding:16px;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0}.kanban-section h4{margin:0 0 12px;font-size:16px;color:#1f2937}.kanban-status{padding:12px;background:#fff;border-radius:6px}.kanban-linked{color:#16a34a;font-weight:600;font-size:14px}.time-tracking-section{margin:24px 0;padding:16px;background:#fef3c7;border-radius:8px;border:1px solid #fbbf24}.time-tracking-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.time-tracking-section h4{margin:0;font-size:16px;color:#1f2937}.time-breakdown{display:flex;gap:12px;flex-wrap:wrap}.time-breakdown-item{font-size:14px;font-weight:600;padding:4px 10px;border-radius:6px;white-space:nowrap}.time-breakdown-item.time-todo{background:#dbeafe;color:#1e40af}.time-breakdown-item.time-kanban{background:#d1fae5;color:#065f46}.time-breakdown-item.time-total{background:#fef3c7;color:#92400e}.total-hours{font-size:18px;font-weight:700;color:#d97706;background:#fff;padding:4px 12px;border-radius:6px}.time-entries-list{margin-bottom:16px}.time-entry-item{background:#fff;border:1px solid #fbbf24;border-radius:6px;padding:12px;margin-bottom:8px}.time-entry-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px;flex-wrap:wrap}.time-hours{background:#d97706;color:#fff;padding:2px 8px;border-radius:4px;font-weight:700;font-size:13px}.time-author{font-weight:600;color:#d97706}.time-date{color:#6b7280;font-size:11px}.time-source{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;margin-left:auto}.time-source-todo{background:#dbeafe;color:#1e40af}.time-source-kanban{background:#d1fae5;color:#065f46}.time-actions{display:flex;gap:4px}.time-edit-btn,.time-delete-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;line-height:1}.time-edit-btn{color:#3b82f6}.time-edit-btn:hover{color:#2563eb}.time-delete-btn{color:#ef4444}.time-delete-btn:hover{color:#dc2626}.time-comment{color:#374151;font-size:14px;line-height:1.5;white-space:pre-wrap}.no-time-entries{color:#9ca3af;font-size:14px;font-style:italic;margin:0 0 12px}.ownership-section{margin:24px 0;padding:16px;background:#e0e7ff;border-radius:8px;border:1px solid #818cf8}.ownership-section h4{margin:0 0 12px;font-size:16px;color:#1f2937}.ownership-info{display:flex;flex-direction:column;gap:8px}.owner-badge,.assigned-users{background:#fff;padding:8px 12px;border-radius:6px;font-size:14px;color:#374151}.owner-badge strong,.assigned-users strong{color:#4f46e5;margin-right:8px}.no-assignment{color:#9ca3af;font-size:14px;font-style:italic;margin:0}.form-field{margin-bottom:16px}.form-field label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:#374151}@media (max-width: 900px){.todo-container{padding:16px}.todo-header{flex-direction:column;align-items:flex-start;gap:12px}.todo-controls{flex-wrap:wrap}.todo-stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media (max-width: 640px){.todo-header h1{font-size:22px}.todo-list{grid-template-columns:1fr}.todo-actions{flex-direction:column;align-items:stretch}.todo-detail-header{flex-direction:column;align-items:flex-start;gap:8px}.time-tracking-section .section-header{flex-direction:column;align-items:flex-start;gap:10px}.modal-content{width:95%;padding:16px}.testing-add{flex-direction:column;align-items:stretch}}.user-profile{max-width:1200px;margin:0 auto;padding:20px}.user-profile-loading,.user-profile-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px;padding:40px;text-align:center}.error-actions{display:flex;flex-direction:column;gap:15px;margin-top:20px;max-width:600px}.error-actions p{color:#666;margin:5px 0}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.profile-header h1{margin:0;color:#333}.profile-section{background:#fff;border-radius:8px;padding:25px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2,.profile-section>h2{margin:0 0 20px;color:#333;font-size:1.5em}.section-header h3,.profile-section h3{margin:0 0 15px;color:#555;font-size:1.2em}.profile-info-grid{display:grid;grid-template-columns:150px 1fr;gap:30px;align-items:start}.profile-picture-container{display:flex;justify-content:center}.profile-picture{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid #007bff}.profile-picture-placeholder{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;color:#fff}.profile-details{display:flex;flex-direction:column;gap:15px}.info-row{display:grid;grid-template-columns:180px 1fr;align-items:center;gap:15px}.info-row label{font-weight:600;color:#555}.info-row span{color:#333}.form-input,.form-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;width:100%;max-width:400px}.form-input:focus,.form-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.badge-admin,.badge-user,.badge-active,.badge-inactive{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.badge-admin{background:#ff6b6b;color:#fff}.badge-user{background:#4ecdc4;color:#fff}.badge-active{background:#51cf66;color:#fff}.badge-inactive{background:#adb5bd;color:#fff}.edit-actions{display:flex;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.settings-grid{display:flex;flex-direction:column;gap:25px}.setting-item{display:flex;flex-direction:column;gap:10px}.setting-item>label{font-weight:600;color:#555;margin-bottom:5px}.notification-options{display:flex;flex-direction:column;gap:12px;margin-top:10px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:#333}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.api-keys-section{margin-bottom:30px}.api-keys-table{width:100%;border-collapse:collapse;margin-top:15px}.api-keys-table thead{background:#f8f9fa}.api-keys-table th,.api-keys-table td{padding:12px;text-align:left;border-bottom:1px solid #e0e0e0}.api-keys-table th{font-weight:600;color:#555;font-size:14px}.api-keys-table td{color:#333;font-size:14px}.scopes{display:flex;gap:5px;flex-wrap:wrap}.scope-badge{padding:2px 8px;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:12px;font-weight:500}.expired{color:#dc3545;font-weight:600}.no-api-keys{color:#6c757d;font-style:italic;margin-top:15px}.sessions-section{margin-top:30px;padding-top:30px;border-top:1px solid #e0e0e0}.session-info{background:#f8f9fa;padding:15px;border-radius:6px;margin-top:10px}.session-info p{margin:8px 0;color:#333}.session-note{color:#6c757d;font-size:14px}.btn-primary,.btn-secondary,.btn-danger,.btn-copy{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3}.btn-primary:disabled{background:#6c757d;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-small{padding:6px 12px;font-size:12px}.btn-copy{background:#28a745;color:#fff;padding:6px 12px;font-size:12px}.btn-copy:hover{background:#218838}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:8px;max-width:600px;width:90%;box-shadow:0 4px 20px #0000004d}.modal-content h2{margin:0 0 20px;color:#333}.api-key-display{margin:20px 0}.warning{background:#fff3cd;color:#856404;padding:12px;border-radius:6px;border-left:4px solid #ffc107;margin-bottom:20px}.key-container{margin-bottom:15px}.key-container label{display:block;font-weight:600;color:#555;margin-bottom:8px}.key-value{display:flex;align-items:center;gap:10px;padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #dee2e6}.key-value code{flex:1;font-family:Courier New,monospace;font-size:14px;color:#495057;word-break:break-all}@media (max-width: 768px){.profile-info-grid{grid-template-columns:1fr;text-align:center}.info-row{grid-template-columns:1fr;text-align:left}.profile-picture-container{margin-bottom:20px}.api-keys-table{font-size:12px}.api-keys-table th,.api-keys-table td{padding:8px}.modal-content{width:95%;padding:20px}}
