:root{--bg-primary: #0f1115;--bg-secondary: #1a1d24;--bg-tertiary: #232730;--text-primary: #f0f2f5;--text-secondary: #a1a3a8;--border-color: #2e323b;--accent-color: #3b82f6;--accent-hover: #60a5fa;--focus-ring: rgba(59, 130, 246, .4);--status-green: #22c55e;--status-yellow: #eab308;--status-red: #ef4444;--status-orange: #f97316;--status-grey: #64748b;--bg-status-green: rgba(34, 197, 94, .15);--bg-status-yellow: rgba(234, 179, 8, .15);--bg-status-red: rgba(239, 68, 68, .15);--bg-status-orange: rgba(249, 115, 22, .15);--bg-status-grey: rgba(100, 116, 139, .15);--font-family-base: "Inter", system-ui, -apple-system, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-base);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;margin-bottom:.5rem}a{color:var(--accent-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}button,input,select,textarea{font-family:inherit;font-size:1rem}button{cursor:pointer;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;padding:.5rem 1rem;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}button:hover{background-color:var(--border-color)}button.primary{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color)}button.primary:hover{background-color:var(--accent-hover);border-color:var(--accent-hover)}button:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}input,select,textarea{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:6px;padding:.5rem .75rem;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--focus-ring)}input::placeholder,textarea::placeholder{color:var(--text-secondary)}.glass-panel{background-color:var(--bg-secondary);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.dashboard-empty{text-align:center;padding:4rem;color:var(--text-secondary)}.dashboard-table-container{overflow-x:auto;border-radius:12px}.dashboard-table{width:100%;border-collapse:collapse;text-align:left;table-layout:fixed}.dashboard-table th,.dashboard-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);word-break:break-word;font-size:.825rem}.dashboard-table th{background-color:var(--bg-tertiary);color:var(--text-secondary);font-weight:500;font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.dashboard-table tr.main-row{transition:background-color .2s}.dashboard-table tr.main-row:hover{background-color:#ffffff05}.main-row.has-comment{cursor:pointer}.main-row.active{background-color:rgba(var(--accent-color-rgb, 59, 130, 246),.05)!important}.font-semibold{font-weight:600;color:#fff}.status-cell{display:flex;align-items:center;justify-content:center}.status-badge{width:14px;height:14px;border-radius:50%;background-color:var(--badge-color);box-shadow:0 0 10px var(--badge-color),inset 0 2px 4px #fff6;transition:transform .15s ease}.status-badge.clickable{cursor:pointer}.status-badge.clickable:hover{transform:scale(1.2)}.th-label-abbrev{display:block;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.projectName-wrapper{display:flex;align-items:center;gap:.75rem;cursor:pointer}.comment-dot{width:6px;height:6px;background-color:var(--accent-color);border-radius:50%;box-shadow:0 0 8px var(--accent-color)}.th-notes-actions,.td-notes-actions{text-align:right}.expansion-row td{padding:0!important;border-bottom:1px solid var(--border-color)}.comment-history-container{background:#0003;padding:1.5rem 2.5rem;border-left:3px solid var(--accent-color);margin:.5rem 1rem 1.5rem 3.5rem;border-radius:8px;box-shadow:inset 0 2px 10px #0000004d}.comment-label{display:flex;align-items:center;gap:.5rem;color:var(--accent-color);font-size:.65rem;font-weight:800;margin-bottom:1rem;letter-spacing:.15em;opacity:.8}.comment-list{max-height:300px;overflow-y:auto;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.comment-item{background:#ffffff08;padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.comment-meta{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.75rem}.comment-author{color:var(--accent-color);font-weight:600}.comment-date{color:var(--text-secondary);opacity:.6}.comment-text{color:var(--text-primary);line-height:1.5;margin:0;white-space:pre-wrap;font-size:.875rem}.no-comments{color:var(--text-secondary);font-style:italic;font-size:.875rem}.add-comment-form{display:flex;gap:.75rem;background:#ffffff0d;padding:.5rem;border-radius:10px;border:1px solid var(--border-color)}.add-comment-form input{flex:1;background:none;border:none;color:#fff;padding:.5rem;font-size:.875rem}.add-comment-form input:focus{outline:none}.send-btn{background:var(--accent-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.send-btn:hover{opacity:.9}.action-buttons{display:flex;gap:.25rem;justify-content:flex-end}.action-btn{background:none;border:none;padding:.4rem;cursor:pointer;color:var(--text-secondary);border-radius:6px;transition:all .2s}.action-btn:hover{background:#ffffff0d}.action-btn.edit:hover{color:var(--accent-color)}.action-btn.delete:hover{color:var(--status-red)}.traffic-light-container{display:flex;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:99px;padding:4px;gap:6px;width:fit-content;box-shadow:inset 0 2px 4px #0003}.traffic-light-container.sm{padding:3px;gap:4px}.traffic-light-container.lg{padding:6px;gap:8px}.light{border-radius:50%;background-color:#ffffff0d;box-shadow:inset 0 2px 4px #0000004d;transition:all .2s ease}.traffic-light-container.interactive .light{cursor:pointer}.traffic-light-container.interactive .light:hover{filter:brightness(1.2);transform:scale(1.1)}.sm .light{width:12px;height:12px}.traffic-light-container:not(.sm):not(.lg) .light{width:16px;height:16px}.lg .light{width:24px;height:24px}.light.active{background-color:var(--light-color);box-shadow:0 0 12px var(--light-color),inset 0 2px 4px #fff6}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-content{width:100%;max-width:600px;max-height:90vh;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.modal-content h2{margin-top:0;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.form-group.row{flex-direction:row;gap:1rem}.form-group .field{flex:1;display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.status-selection-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.status-selection-card h3{font-size:1rem;margin-top:0;margin-bottom:1rem;color:var(--text-secondary)}.statuses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.status-row{display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-secondary);padding:.75rem 1rem;border-radius:6px;border:1px solid var(--border-color)}.status-label{font-size:.875rem;font-weight:500}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%}.login-card{width:100%;max-width:400px;padding:2.5rem;border-radius:16px;text-align:center}.login-header{margin-bottom:2rem}.login-header h2{font-size:1.5rem;font-weight:600;margin:1rem 0 .5rem;letter-spacing:-.02em}.login-header p{color:var(--text-secondary);font-size:.95rem}.login-form{text-align:left}.login-form .form-group{margin-bottom:1.5rem}.login-error{background-color:#dc262626;border:1px solid var(--status-red);color:#ffb3b3;padding:.75rem;border-radius:8px;margin-bottom:1.5rem;font-size:.875rem}.full-width{width:100%;justify-content:center;margin-top:.5rem;padding:.75rem;font-size:1rem}.security-modal{width:400px;padding:2rem;position:relative}.security-content{margin-top:1.5rem}.security-intro{text-align:center}.security-intro p{margin-bottom:2rem;color:var(--text-secondary)}.setup-flow{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.qr-container{background:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem}.qr-container img{display:block;width:200px;height:200px}.manual-secret{text-align:center;margin-bottom:1rem}.manual-secret code{background:#ffffff1a;padding:2px 6px;border-radius:4px;display:block;margin-top:4px;font-family:monospace;font-size:1.1rem}.verify-form{width:100%}.success-message{text-align:center}.success-message h3{color:#4ade80;margin-bottom:1rem}.user-modal{width:90%;max-width:900px;max-height:85vh;border-radius:20px;padding:0;overflow:hidden;position:relative}.user-management-content{padding:2rem;overflow-y:auto;max-height:calc(85vh - 70px)}.create-user-section{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1)}.create-user-section h3{margin-bottom:1rem;color:var(--text-primary)}.helper-text{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;opacity:.7}.inline-form-group{display:flex;gap:1rem}.inline-form-group input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.management-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}.item-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.user-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:10px}.user-info{display:flex;flex-direction:column;gap:.25rem}.username{font-weight:500;color:var(--text-primary)}.role-badge{font-size:.65rem;padding:.1rem .4rem;border-radius:4px;font-weight:700;text-transform:uppercase}.role-badge.admin{background:#3b82f633;color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.role-badge.user{background:#ffffff1a;color:var(--text-secondary);border:1px solid rgba(255,255,255,.1)}.two-fa-status{font-size:.7rem;color:#10b981;display:flex;align-items:center;gap:.25rem}.inv-date{font-size:.7rem;color:var(--text-secondary);opacity:.6}.row-actions{display:flex;gap:.5rem}.action-icon-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.4rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.action-icon-btn:hover{background:#ffffff1a;color:var(--accent-color)}.delete-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:.4rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;opacity:.6}.delete-btn:hover{background:#ef44441a;opacity:1}.empty-text{font-size:.85rem;color:var(--text-secondary);font-style:italic;opacity:.5;text-align:center;margin-top:1rem}@media(max-width:768px){.management-grid{grid-template-columns:1fr;gap:2rem}.inline-form-group{flex-direction:column}}.mb-1{margin-bottom:1rem}.user-management-content::-webkit-scrollbar{width:6px}.user-management-content::-webkit-scrollbar-track{background:transparent}.user-management-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.user-management-content::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{min-height:100vh;display:flex;flex-direction:column}.header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}.header h1{margin:0;font-size:1.5rem;display:flex;align-items:center;gap:.75rem}.main-content{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:2rem}.toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.filters{display:flex;gap:1rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem;background-color:var(--bg-secondary);padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border-color)}.filter-group label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.filter-group select,.filter-group input{background-color:transparent;border:none;padding:0;color:var(--text-primary);font-size:.875rem;outline:none;box-shadow:none;cursor:pointer}.filter-group select option{background-color:var(--bg-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease-out forwards}
