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}*{margin:0;padding:0;box-sizing:border-box;font-family:Noto Sans,sans-serif}body{background-color:#f5f7fa;padding:2rem;color:#2d3748}.header{display:none}.board{display:flex;flex-direction:column;gap:1.5rem}.task-pile{background:#fff;padding:1rem;border-radius:12px;box-shadow:0 4px 6px #0000000d}.task-pile .tasks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.task-pile .task{margin-bottom:0;height:100%;display:flex;flex-direction:column}.tech-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.column{background:#fff;padding:1rem;border-radius:12px;box-shadow:0 4px 6px #0000000d;min-height:300px;transition:box-shadow .3s ease}.column:hover{box-shadow:0 6px 12px #00000014}.column-header{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #edf2f7;color:#2d3748}.task{background:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #edf2f7;cursor:move;transition:all .2s ease;box-shadow:0 2px 4px #00000005}.task:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000014;border-color:#e2e8f0}.task.dragging{opacity:.5;box-shadow:0 8px 16px #0000001f}.task-title{font-weight:600;color:#2d3748;margin-bottom:.25rem;font-size:.9rem}.task-description{font-size:.8rem;color:#718096;line-height:1.3}.column.highlight,.task-pile.highlight{background-color:#f7fafc;border:2px dashed #4299e1}.add-task-button{background:none;border:none;color:#4299e1;font-size:1.5rem;cursor:pointer;padding:0 .5rem;transition:all .2s ease;border-radius:6px}.add-task-button:hover{transform:scale(1.1);color:#2b6cb0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:500px;box-shadow:0 4px 20px #00000026;animation:modalFade .3s ease}@keyframes modalFade{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-size:1.1rem;color:#2d3748;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#a0aec0;transition:color .2s ease}.close-button:hover{color:#2d3748}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#4a5568;font-weight:500;font-size:.85rem}.form-group input,.form-group textarea{width:100%;padding:.5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;transition:all .2s ease;color:#2d3748;background:#f7fafc}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126;background:#fff}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.submit-button,.delete-button{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease;flex:1}.submit-button{background:#4299e1;color:#fff}.submit-button:hover{background:#2b6cb0}.delete-button{background:#fc8181;color:#fff}.delete-button:hover{background:#e53e3e}.task.updated{animation:highlight 1s ease-out}@keyframes highlight{0%{background-color:#ebf8ff}to{background-color:#fff}}@media (max-width: 1800px){.board{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1400px){.tech-columns{grid-template-columns:repeat(2,1fr)}}@media (max-width: 800px){.tech-columns{grid-template-columns:1fr}}@media (max-width: 600px){.board{grid-template-columns:1fr}.app-container{padding:0 1rem}.chat-container{height:400px}.task-pile .tasks-grid{grid-template-columns:1fr}}.app-container{display:flex;flex-direction:column;gap:1rem;max-width:2000px;margin:0 auto;padding:1rem}.board-container{width:100%}.chat-container{width:100%;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;display:flex;flex-direction:column;height:250px;margin-top:auto}.chat-header{padding:.75rem;border-bottom:2px solid #edf2f7;display:flex;justify-content:space-between;align-items:center}.chat-header h2{font-size:.9rem;color:#2d3748;font-weight:600}.messages-container{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;background:#f8fafc;border:1px solid #e2e8f0;margin:.5rem;border-radius:8px}.message{background:#fff;padding:.75rem;border-radius:8px;max-width:100%;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.message-sender{font-weight:600;color:#4a5568;font-size:.8rem}.message-time{color:#718096;font-size:.7rem}.message-text{color:#2d3748;font-size:.85rem;line-height:1.3;word-break:break-word}.chat-input-form{padding:1rem;border-top:2px solid #edf2f7;display:flex;gap:.5rem}.chat-input{flex:1;padding:.5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;transition:all .2s ease;background:#f7fafc}.chat-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126;background:#fff}.chat-send-button{padding:.5rem 1rem;background:#4299e1;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s ease;font-size:.85rem}.chat-send-button:hover{background:#2b6cb0}.chat-user{font-size:.75rem;color:#718096;margin-top:.25rem}.no-messages{text-align:center;color:#718096;padding:2rem;font-style:italic}.message-own{background:#ebf8ff;margin-left:auto;border-color:#90cdf4}.chat-send-button:disabled{background:#cbd5e0;cursor:not-allowed}.column,.task-pile{transition:background-color .2s,border .2s}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;width:100%}.loading-spinner{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#4299e1;font-weight:500}.task.priority-high{background:#ffe5e5;border-left:4px solid #ff9999}.task.priority-medium{background:#fff5e6;border-left:4px solid #ffcc80}.task.priority-low{background:#e6ffe6;border-left:4px solid #99ff99}.priority-select{width:100%;padding:.5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;background:#f7fafc;color:#2d3748;cursor:pointer}.priority-select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126;background:#fff}.task.priority-high:hover{background:#ffd9d9;border-left-color:#ff8080}.task.priority-medium:hover{background:#ffebcc;border-left-color:#fb3}.task.priority-low:hover{background:#d9ffd9;border-left-color:#80ff80}.generating-label{font-size:.75rem;color:#4299e1;margin-left:.5rem;font-weight:400;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.form-group input[disabled]{background-color:#f7fafc;cursor:wait}.generated-title{background-color:#f7fafc!important;cursor:not-allowed;color:#4a5568!important;border:1px dashed #cbd5e0!important}.generated-title::placeholder{color:#a0aec0;font-style:italic}.form-group label[for=taskTitle]:after{content:" (AI Generated)";font-size:.75rem;color:#4299e1;font-weight:400}@keyframes typing{0%{width:0}to{width:100%}}@keyframes blink{50%{border-color:transparent}}.task.new-task .task-title{white-space:nowrap;overflow:hidden;border-right:2px solid #4299e1;width:0;animation:typing 1s steps(30,end) forwards,blink 1s step-end infinite}.task.new-task .task-description{opacity:0;animation:fadeIn .5s ease-in forwards;animation-delay:1s}.task-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.shared-indicator{font-size:1.1rem;margin-left:.5rem;cursor:help}.shared-with{margin-top:.5rem;font-size:.75rem;color:#718096;font-style:italic;border-top:1px solid rgba(0,0,0,.1);padding-top:.5rem}.task .shared-indicator{animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.complete-button{position:absolute;bottom:.75rem;right:.75rem;width:28px;height:28px;border-radius:50%;border:none;background:#edf2f7;color:#718096;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1.1rem;opacity:0}.task:hover .complete-button{opacity:1}.complete-button:hover{background:#48bb78;color:#fff;transform:scale(1.1)}.complete-button:before{content:"✓";line-height:1}.task-edit-modal{max-width:600px;width:90%}.modal-content{max-height:80vh;overflow-y:auto}.task-comments-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #E2E8F0}.task-comments-section h3{color:#2d3748;font-size:1.1rem;margin-bottom:1rem}.comments-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.comment{background:#f7fafc;padding:1rem;border-radius:8px;border-left:3px solid #4299E1}.comment-header{display:flex;justify-content:space-between;align-items:flex-start}.comment-author-section{display:flex;flex-direction:column;gap:.25rem}.comment-actions{display:flex;gap:.5rem;opacity:0;transition:opacity .2s}.comment:hover .comment-actions{opacity:1}.comment-actions button{background:none;border:none;padding:.25rem;cursor:pointer;font-size:1rem;line-height:1;border-radius:4px;transition:all .2s}.comment-actions .edit-button{color:#4299e1}.comment-actions .edit-button:hover{background:#ebf8ff}.comment-actions .delete-button{color:#e53e3e}.comment-actions .delete-button:hover{background:#fed7d7}.edit-comment-form{display:flex;flex-direction:column;gap:.75rem}.edit-comment-form textarea{width:100%;padding:.75rem;border:1px solid #E2E8F0;border-radius:6px;resize:vertical;font-size:.9rem;min-height:60px;background:#fff}.edit-comment-form .edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.edit-comment-form button{padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.edit-comment-form .save-button{background:#48bb78;color:#fff}.edit-comment-form .save-button:hover{background:#38a169}.edit-comment-form .cancel-button{background:#edf2f7;color:#4a5568}.edit-comment-form .cancel-button:hover{background:#e2e8f0}.comment-author{font-weight:600;color:#2d3748}.comment-content{color:#4a5568;font-size:.9rem;line-height:1.4}.add-comment-form{display:flex;flex-direction:column;gap:.75rem}.add-comment-form textarea{width:100%;padding:.75rem;border:1px solid #E2E8F0;border-radius:6px;resize:vertical;font-size:.9rem;background:#f7fafc}.add-comment-form textarea:focus{outline:none;border-color:#4299e1;background:#fff}.add-comment-form button{align-self:flex-end;padding:.5rem 1rem;background:#4299e1;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s}.add-comment-form button:hover{background:#3182ce}.comment-badge{display:inline-flex;align-items:center;background:#ebf8ff;color:#4299e1;padding:.2rem .5rem;border-radius:9999px;font-size:.75rem;margin-left:.5rem;font-weight:500}.modal-tabs{display:flex;border-bottom:2px solid #E2E8F0;margin-bottom:1.5rem}.tab-button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:#718096;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.tab-button:hover{color:#4a5568}.tab-button.active{color:#4299e1;border-bottom-color:#4299e1}.task-title{display:flex;align-items:center;gap:.5rem}.comment{animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.task-icon{margin-right:8px;color:#4a5568;font-size:.875rem}@media screen and (max-width: 768px){body{padding:1rem}.tech-columns{grid-template-columns:1fr;gap:1rem}.column{min-width:auto}.task-pile .tasks-grid{grid-template-columns:1fr}.task-form{padding:1rem}.form-grid{grid-template-columns:1fr;gap:1rem}.task-actions{flex-direction:column;gap:.5rem}.task-actions button{width:100%}.task-meta{flex-wrap:wrap;gap:.5rem}.comment-section{padding:.75rem}.add-comment-form{flex-direction:column;gap:.5rem}.add-comment-form button{width:100%}}@media screen and (min-width: 769px) and (max-width: 1024px){.tech-columns,.task-pile .tasks-grid,.form-grid{grid-template-columns:repeat(2,1fr)}}@media screen and (max-width: 480px){.task{padding:.75rem}.task-header{flex-direction:column;align-items:flex-start;gap:.5rem}.task-title{font-size:1rem}.task-description{font-size:.9rem}.task-meta span{font-size:.8rem}.status-badge{padding:.25rem .5rem;font-size:.75rem}.comment{padding:.75rem}.comment-header{flex-direction:column;align-items:flex-start}}.completed-tasks{padding:2rem;max-width:1200px;margin:0 auto}.completed-tasks h1{color:#2d3748;margin-bottom:2rem}.completed-tasks-list{display:flex;flex-direction:column;gap:1rem}.completed-task{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000000d;animation:slideIn .3s ease-out;border-left:4px solid}.completed-task.priority-high{border-color:#f99;background:linear-gradient(to right,#ffe5e5,#fff)}.completed-task.priority-medium{border-color:#ffcc80;background:linear-gradient(to right,#fff5e6,#fff)}.completed-task.priority-low{border-color:#9f9;background:linear-gradient(to right,#e6ffe6,#fff)}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.completed-date{color:#718096;font-size:.85rem}.completion-summary{color:#4a5568;margin:1rem 0;line-height:1.5}.task-details{display:flex;gap:1rem;font-size:.9rem;color:#718096}.complete-button{position:absolute;bottom:.5rem;right:.5rem;width:24px;height:24px;border-radius:50%;border:2px solid #4299e1;background:#fff;color:#4299e1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.complete-button:hover{background:#4299e1;color:#fff}.task{position:relative;padding-bottom:2rem}.no-completed-tasks{text-align:center;padding:2rem;color:#718096;font-style:italic;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.completed-task h3{color:#2d3748;font-size:1.1rem;margin:0}.completed-date{font-size:.85rem;color:#718096}.completion-summary{margin:1rem 0;color:#4a5568;line-height:1.5}.completed-task-actions{display:flex;align-items:center;gap:1rem}.delete-completed-task{background:none;border:none;color:#a0aec0;font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0}.completed-task:hover .delete-completed-task{opacity:1}.delete-completed-task:hover{background:#fed7d7;color:#e53e3e}.delete-completed-task:disabled{cursor:not-allowed;opacity:.5}.completed-task.deleting{animation:fadeOut .3s ease forwards}@keyframes fadeOut{to{opacity:0;transform:translate(-20px)}}.completed-task-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-right:.5rem}.undo-button{padding:.25rem .75rem;background:#edf2f7;color:#4a5568;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.undo-button:hover{background:#e2e8f0}.task-header{display:flex;justify-content:space-between;align-items:center}.sorting-controls{display:flex;gap:10px;margin-bottom:20px;align-items:center}.sort-select{padding:8px;border:1px solid #ddd;border-radius:4px;background-color:#fff;font-size:14px;cursor:pointer}.sort-order-button{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background-color:#fff;cursor:pointer;font-size:16px;transition:all .2s;color:#555}.sort-order-button:hover{background-color:#f0f0f0;border-color:#999}.filter-controls{display:flex;gap:15px;margin-bottom:20px;align-items:center;padding:15px;background-color:#f8f9fa;border-radius:6px}.user-filter{display:flex;align-items:center;gap:10px;flex:1}.user-filter label{font-weight:500;color:#555}.user-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background-color:#fff;font-size:14px;cursor:pointer;min-width:150px}.user-select:hover{border-color:#999}@media screen and (max-width: 768px){.completed-tasks,.completed-task{padding:1rem}.task-header{flex-direction:column;align-items:flex-start;gap:.75rem}.task-actions{width:100%;justify-content:flex-start;gap:.5rem;flex-wrap:wrap}.task-meta{flex-wrap:wrap;gap:.5rem}.completion-summary{padding:.75rem}.summary-header{flex-direction:column;align-items:flex-start;gap:.5rem}.summary-content{padding:.75rem}.user-select{width:100%}}@media screen and (min-width: 769px) and (max-width: 1024px){.completed-tasks{padding:1.5rem}.task-meta{flex-wrap:wrap}}@media screen and (max-width: 480px){.completed-tasks h1{font-size:1.5rem;margin-bottom:1rem}.task-title{font-size:1rem}.task-description{font-size:.9rem}.meta-item{font-size:.8rem}.status-badge{padding:.25rem .5rem;font-size:.75rem}.completion-time,.completed-by{font-size:.8rem}.task-actions button{padding:.5rem .75rem;font-size:.8rem}}.settings-container{padding:2rem;max-width:800px;margin:0 auto}.settings-container h1{color:#2d3748;margin-bottom:2rem}.agents-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 4px #0000000d}.agents-section h2{color:#4a5568;margin-bottom:1.5rem}.add-agent-form{display:flex;gap:1rem;margin-bottom:2rem}.add-agent-form input{padding:.5rem 1rem;border:1px solid #E2E8F0;border-radius:6px;font-size:.9rem}.add-agent-form button{padding:.5rem 1rem;background:#4299e1;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.add-agent-form button:hover{background:#3182ce}.agents-list{display:grid;gap:1rem}.agent-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f7fafc;border-radius:8px;border:1px solid #E2E8F0}.agent-info h3{color:#2d3748;margin:0;font-size:1rem}.agent-info p{color:#718096;margin:.25rem 0 0;font-size:.9rem}.agent-actions{display:flex;gap:.5rem}.agent-actions button{padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.edit-agent-form{display:flex;flex-direction:column;gap:1rem;width:100%}.edit-agent-form input{padding:.5rem;border:1px solid #E2E8F0;border-radius:4px;font-size:.9rem;flex:1}.edit-actions button{padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.save-button{background:#48bb78;color:#fff}.cancel-button{background:#edf2f7;color:#4a5568}.default-badge{font-size:.7rem;background:#e6fffa;color:#319795;padding:.2rem .5rem;border-radius:4px;margin-left:.5rem;text-transform:uppercase;font-weight:600}.edit-inputs{display:flex;gap:1rem;flex:1}.current-user-badge{font-size:.7rem;background:#c6f6d5;color:#2f855a;padding:.2rem .5rem;border-radius:4px;margin-left:.5rem;text-transform:uppercase;font-weight:600}.link-button{background:#ebf8ff;color:#4299e1;padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.link-button:hover{background:#bee3f8}.unlink-button{background:#fed7d7;color:#e53e3e;padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.unlink-button:hover{background:#feb2b2}.App{text-align:center}.App-header{background-color:#282c34;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:calc(10px + 2vmin);color:#fff}.app-nav{background:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000000d;display:flex;gap:2rem;position:sticky;top:0;z-index:100}.nav-link{color:#4a5568;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;display:flex;align-items:center}.nav-link:hover{background:#edf2f7;color:#2d3748}.nav-link.active{background:#e6fffa;color:#319795}.unread-badge{background:#e53e3e;color:#fff;font-size:.75rem;padding:.1rem .4rem;border-radius:9999px;margin-left:.5rem;font-weight:700}.app-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem}.nav-links{display:flex;gap:2rem}.logout-button{padding:.5rem 1rem;background:#edf2f7;color:#4a5568;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s}.logout-button:hover{background:#e2e8f0;color:#2d3748}.app-nav.no-sticky{position:static}.message-board{padding:2rem;max-width:1200px;margin:0 auto}.message-board h1{color:#2d3748;margin-bottom:2rem}.message-board h2{color:#2d3748;margin-bottom:1rem;font-size:1.25rem}.message-board-content{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}.message-form-container{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 4px #0000000d;position:sticky;top:2rem}.agent-select{width:100%;padding:.5rem;margin-bottom:1rem;border:1px solid #E2E8F0;border-radius:6px;font-size:.9rem}.message-form{display:flex;flex-direction:column;gap:1rem}.message-form textarea{width:100%;min-height:100px;padding:.75rem;border:1px solid #E2E8F0;border-radius:6px;resize:vertical;font-size:.9rem}.message-form button{align-self:flex-end;padding:.5rem 1rem;background:#4299e1;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.message-form button:hover{background:#3182ce}.message-form button:disabled{background:#cbd5e0;cursor:not-allowed}.messages-container{display:flex;flex-direction:column;gap:1rem}.message{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 4px #0000000d;cursor:pointer;transition:all .2s ease}.message.unread{border-left:4px solid #4299E1;background:linear-gradient(to right,#ebf8ff,#fff)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.author{font-weight:600;color:#2d3748}.timestamp{color:#718096;font-size:.85rem}.message-content{color:#4a5568;line-height:1.5;margin-bottom:1rem;white-space:pre-wrap}.message-footer{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#718096}.read-by{font-style:italic}.message-board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.current-user{display:flex;align-items:center;gap:1rem;font-size:.9rem;color:#4a5568}.switch-user{padding:.25rem .75rem;background:#edf2f7;border:none;border-radius:4px;color:#4a5568;cursor:pointer;transition:all .2s}.switch-user:hover{background:#e2e8f0}.select-agent-prompt{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 4px #0000000d;text-align:center}.agent-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem}.agent-button{padding:.75rem 1.5rem;background:#ebf8ff;color:#4299e1;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-size:1rem}.agent-button:hover{background:#bee3f8;transform:translateY(-1px)}.message-actions{display:flex;gap:.5rem}.message-actions button{padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s}.edit-button{background:#ebf8ff;color:#4299e1}.edit-button:hover{background:#bee3f8}.delete-button{background:#fed7d7;color:#e53e3e}.delete-button:hover{background:#feb2b2}.edit-message-form{margin:1rem 0}.edit-message-form textarea{width:100%;min-height:80px;padding:.75rem;border:1px solid #E2E8F0;border-radius:6px;resize:vertical;font-size:.9rem;margin-bottom:.5rem}.edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.save-button{padding:.25rem .75rem;background:#48bb78;color:#fff;border:none;border-radius:4px;cursor:pointer}.cancel-button{padding:.25rem .75rem;background:#edf2f7;border:none;border-radius:4px;color:#4a5568;cursor:pointer}.message.edited .timestamp:after{content:" (edited)";font-style:italic}.header-actions{display:flex;align-items:center;gap:1rem}.mark-all-read{padding:.25rem .75rem;background:#ebf8ff;color:#4299e1;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.mark-all-read:hover{background:#bee3f8}@media screen and (max-width: 768px){.message-board{padding:1rem}.message-board-content{grid-template-columns:1fr;gap:1rem}.message-form-container{position:relative;top:0;margin-bottom:1rem;padding:1rem}.message-list{margin-top:1rem}.message-item{padding:1rem}.message-header{flex-direction:column;align-items:flex-start;gap:.5rem}.message-meta{width:100%;justify-content:space-between}.message-actions{width:100%;justify-content:flex-end}}@media screen and (min-width: 769px) and (max-width: 1024px){.message-board-content{grid-template-columns:300px 1fr;gap:1.5rem}.message-form-container{padding:1.25rem}}@media screen and (max-width: 480px){.message-board h1{font-size:1.5rem;margin-bottom:1rem}.message-form textarea{min-height:80px}.message-item{margin-bottom:.75rem}.message-content{font-size:.9rem}.message-time{font-size:.75rem}.agent-select{font-size:.85rem}}.terminal-container{display:flex;justify-content:center;align-items:center;min-height:100vh;height:100vh;background-color:#1a1a1a;font-family:Courier New,monospace;padding:0;margin:0;position:fixed;top:0;left:0;right:0;bottom:0}.terminal{width:90vw;height:90vh;max-width:none;background-color:#2b2b2b;border-radius:10px;box-shadow:0 10px 30px #0006;overflow:hidden;display:flex;flex-direction:column}.terminal-header{background-color:#1a1a1a;padding:10px;display:flex;gap:8px;border-bottom:1px solid #3a3a3a}.terminal-button{width:12px;height:12px;border-radius:50%}.terminal-button.red{background-color:#ff5f56}.terminal-button.yellow{background-color:#ffbd2e}.terminal-button.green{background-color:#27c93f}.terminal-content{padding:30px;color:#0abab5;font-size:1.2rem;line-height:1.6;flex-grow:1;display:flex;flex-direction:column;overflow-y:auto}.terminal-text{white-space:pre-wrap;margin-bottom:20px;flex-grow:1;display:flex;flex-direction:column;justify-content:center}.terminal-cursor{display:inline-block;width:10px;height:20px;background-color:#0abab5;vertical-align:bottom;margin-left:2px}.terminal-login{margin-top:30px;opacity:0;text-align:center}.terminal-button-login{background-color:transparent;border:2px solid #0abab5;color:#0abab5;padding:12px 24px;font-family:Courier New,monospace;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:10px}.terminal-button-login:hover{background-color:#0abab5;color:#2b2b2b}.terminal-button-login:disabled{opacity:.6;cursor:not-allowed}.terminal-error{color:#ff5f56;margin-top:20px;text-align:center}.terminal{position:relative}.terminal:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;box-shadow:0 0 20px #0abab533;border-radius:10px;opacity:0}.app{height:100vh}html,body{margin:0;padding:0;height:100%;width:100%}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#81d8d0,#5fb4ac);padding:2rem;position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden}.login-container:before,.login-container:after{content:"";position:absolute;background:#ffffff1a;border-radius:50%;filter:blur(60px);transform-origin:center}.login-container:before{width:500px;height:500px;top:-250px;right:-100px;animation:lavaMove1 15s infinite alternate ease-in-out}.login-container:after{width:400px;height:400px;bottom:-200px;left:-100px;animation:lavaMove2 18s infinite alternate-reverse ease-in-out}@keyframes lavaMove1{0%{transform:translate(0) scale(1)}50%{transform:translate(-100px,200px) scale(1.2)}to{transform:translate(100px,300px) scale(.8)}}@keyframes lavaMove2{0%{transform:translate(0) scale(1)}50%{transform:translate(150px,-100px) scale(1.3)}to{transform:translate(-50px,-200px) scale(.9)}}.login-container:before{box-shadow:400px 400px 100px #ffffff1a,-400px 200px 100px #ffffff1a}.login-box{background:#fffffff2;padding:2rem;border-radius:1rem;box-shadow:0 20px 40px #0000001a;width:100%;max-width:450px;text-align:center;position:relative;z-index:1;animation:fadeIn .8s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.logo-container{margin-bottom:1.5rem;position:relative}.school-logo{width:120px;height:120px;margin:0 auto;object-fit:contain;transition:transform .3s ease}.school-logo:hover{transform:scale(1.05)}.logo-container:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140px;height:140px;background:radial-gradient(circle,#81d8d033,#81d8d000 70%);border-radius:50%;z-index:-1}.login-box h1{color:#1a202c;margin:0 0 .5rem;font-size:1.25rem;font-weight:700;line-height:1.3}.login-description{color:#4a5568;margin-bottom:1.5rem;font-size:.9rem}.google-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.75rem;background:#81d8d0;border:none;border-radius:.5rem;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.google-button:hover{background:#5fb4ac;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.google-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.error-message{margin-top:1rem;padding:.75rem;background:#fee2e2;border:1px solid #FCA5A5;border-radius:.5rem;color:#dc2626;font-size:.875rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.loading-message{color:#81d8d0;font-size:1rem;font-weight:500}@media (max-width: 360px){.login-container{padding:1rem}.login-box{padding:1.5rem}.login-box h1{font-size:1.1rem}}.app-nav{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.nav-brand{display:flex;align-items:center;gap:.75rem;color:#2d3748;font-size:1.25rem;font-weight:600}.nav-brand:before{content:"";width:24px;height:24px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath fill='%2381D8D0' d='M128 208v48h256v-48H128zm0 96v48h256v-48H128zM128 0v48h256V0H128zm0 416v48h256v-48H128z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat}.logout-button{padding:.5rem 1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:.375rem;color:#4a5568;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.logout-button:hover{background:#edf2f7;border-color:#cbd5e0}.ticket-system{display:flex;flex-direction:column;min-height:100vh;background-color:#f7fafc}.content-container.split-view{display:flex;gap:2rem;padding:2rem;flex:1}.form-section{flex:0 0 40%;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column}.type-selector{display:flex;gap:1rem;margin-bottom:2rem}.type-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-weight:500;cursor:pointer;transition:all .2s}.type-button:hover{background:#f7fafc}.type-button.active{background:#6b46c1;color:#fff;border-color:#6b46c1}.type-button svg{font-size:1.2rem}.tickets-list.staff-view{flex:0 0 60%;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.tickets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.tickets-header h2{color:#2d3748;margin:0;font-size:1.5rem}.facilities-board{padding:20px;width:100%}.filter-button{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;background-color:#fff;color:#4a5568;cursor:pointer;transition:all .2s;font-weight:500;font-size:.875rem}.filter-button.active{background-color:#6b46c1;color:#fff;border-color:#6b46c1}.ticket-form-container{flex:1;max-width:600px}.no-tickets{text-align:center;padding:40px;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#4a5568}.ticket-nav{max-width:1200px;margin:0 auto 2rem;background:#fff;border-radius:8px;padding:.5rem;display:flex;gap:.5rem;box-shadow:0 1px 3px #0000001a}.nav-button{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-radius:6px;font-size:.95rem;font-weight:500;color:#4a5568;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.nav-button svg{width:16px;height:16px}.nav-button:hover{background:#f7fafc;color:#2d3748}.nav-button.active{background:#81d8d0;color:#fff}.tickets-container{max-width:1200px;margin:0 auto;height:calc(100% - 4rem);display:flex;flex-direction:column}.content-container{flex:1;padding:20px;overflow-y:auto}.content-container.split-view{flex-direction:row}.tech-tickets-container{display:flex;gap:2rem;width:100%}.tickets-column{flex:1;min-width:0}.tickets-column h2{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#2d3748;font-size:1.25rem}.tickets-column h2 svg{color:#4a5568}.form-section{flex:0 0 40%;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;overflow-y:auto}.tickets-list{flex:0 0 60%;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.tickets-list h2{margin-bottom:24px;color:#333;font-size:1.5rem}.type-selector{display:flex;gap:1rem;margin-bottom:1rem}.type-button{flex:1;padding:.75rem;border:1px solid #81D8D0;border-radius:8px;background:#fff;color:#2c5282;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.type-button svg{width:16px;height:16px}.type-button:hover{background:#f0faf9}.type-button.active{background:#81d8d0;color:#fff}.ticket-card{border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:1rem;background:#fff}.ticket-card:last-child{margin-bottom:0}.ticket-badges{display:flex;gap:8px;align-items:center}.badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge.tech-responded{background-color:#6b46c1;color:#fff}.badge.facilities-responded{background-color:#ff6f61;color:#fff}.badge.closed{background-color:#718096;color:#fff}.ticket-header{padding:1.25rem;cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start}.ticket-header-content{flex:1}.ticket-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ticket-actions{display:flex;gap:.5rem;margin-left:1rem}.icon-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;padding:0}.icon-button svg{width:16px;height:16px}.icon-button.edit-button{background:#e0f7f6;color:#2c7a7b}.icon-button.edit-button:hover{background:#b2f5ea}.icon-button.delete-button{background:#ffe8e8;color:#e88b8b}.icon-button.delete-button:hover{background:#ffd1d1}.submit-button{width:100%;padding:.75rem;background:#81d8d0;border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.submit-button:hover{background:#5fb4ac}.ticket-system-header{max-width:1200px;margin:0 0 2rem;display:flex;gap:1rem}.view-toggle{flex:1;padding:1rem;background:#fff;border:1px solid #81D8D0;border-radius:8px;font-size:1rem;font-weight:500;color:#2c5282;cursor:pointer;transition:all .2s}.view-toggle:hover{background:#f0faf9}.view-toggle.active{background:#81d8d0;color:#fff;border-color:#81d8d0}.tickets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.tickets-header h2{margin:0;color:#2c3e50;font-size:1.75rem;font-weight:600;letter-spacing:-.025em}.status-filter{display:flex;gap:.5rem}.filter-button{padding:.5rem 1rem;border:1px solid #E2E8F0;background:#fff;color:#4a5568;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.filter-button:hover{background:#f7fafc;border-color:#cbd5e0}.filter-button.active{background:#4a5568;color:#fff;border-color:#4a5568}.filter-controls{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1rem;border-radius:8px;box-shadow:0 1px 2px #0000000d;border:1px solid #e2e8f0}.filter-icon{color:#81d8d0;width:16px;height:16px}.type-filter{border:none;background:transparent;font-size:.95rem;color:#1e293b;padding:.25rem;cursor:pointer;font-weight:500}.type-filter:focus{outline:none}.ticket-type{font-size:.8rem;font-weight:500;padding:.25rem .75rem;border-radius:20px}.ticket-type.type-it{background:#e0f7f6;color:#2c7a7b}.ticket-type.type-facilities{background:#e6fffa;color:#2c7a7b}.ticket-time{color:#64748b;font-size:.85rem}.ticket-header h3{display:flex;align-items:center;margin:8px 0;font-size:1.1rem;color:#2d3748}.ticket-author{font-size:.9rem;color:#64748b}.ticket-status-section{display:flex;align-items:center;gap:1rem}.ticket-status{font-size:.8rem;font-weight:500;padding:.25rem .75rem;border-radius:20px;background:#f1f5f9;color:#475569;text-transform:capitalize}.ticket-content{padding:0 1.25rem 1.25rem;animation:slideDown .3s ease-out}.ticket-description{color:#475569;font-size:.95rem;line-height:1.6;white-space:pre-wrap;margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:8px}.actions-container{display:flex;justify-content:flex-end;gap:.5rem;margin:1rem 0}.comments-section{margin-top:1.5rem;border-top:1px solid #e2e8f0;padding-top:1.5rem}.comments-section h4{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:#1e293b;font-size:1rem}.comment-count{background:#f1f5f9;padding:.2rem .6rem;border-radius:20px;font-size:.8rem;color:#64748b}.comment-item{display:flex;gap:1rem;margin-bottom:1rem;padding:1rem;background:#f8fafc;border-radius:8px;animation:fadeIn .3s ease-out}.comment-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.comment-avatar.technician{background-color:#6b46c1;color:#fff}.comment-avatar.facilities{background-color:#ff6f61;color:#fff}.comment-avatar.teacher{background-color:#81d8d0;color:#fff}.comment-content{flex:1}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.comment-author{font-weight:500;color:#1e293b;display:flex;align-items:center;gap:.5rem}.role-badge{background-color:#6b46c1;color:#fff;font-size:.75rem;padding:2px 6px;border-radius:4px;margin-left:8px}.comment-time{font-size:.85rem;color:#64748b}.comment-text{margin:0;color:#475569;font-size:.95rem;line-height:1.6}.comment-form{margin-top:1rem;display:flex;gap:.75rem}.comment-form textarea{flex:1;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;resize:vertical;min-height:60px;font-size:.95rem}.comment-form textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.comment-form button{background-color:#81d8d0;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.comment-form button:hover{background-color:#6bc1b8}.edit-form{margin-top:1rem}.edit-form textarea{width:100%;min-height:100px;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.edit-form textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.edit-buttons{display:flex;gap:.75rem}.edit-buttons button{padding:.5rem 1rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.edit-buttons button:first-child{background:#3b82f6;color:#fff}.edit-buttons button:first-child:hover{background:#2563eb}.edit-buttons button:last-child{background:#f1f5f9;color:#64748b}.edit-buttons button:last-child:hover{background:#e2e8f0}.ticket-title-icon{margin-right:8px;color:#2d3748}.tech-response-badge{background-color:#6b46c1;color:#fff;font-size:.75rem;padding:2px 8px;border-radius:12px;margin-left:8px}.description-textarea{width:100%;min-height:200px;padding:12px;border:1px solid #E2E8F0;border-radius:8px;font-size:1rem;line-height:1.5;resize:vertical;transition:border-color .2s ease}.description-textarea:focus{outline:none;border-color:#81d8d0;box-shadow:0 0 0 2px #81d8d033}.description-textarea::placeholder{color:#a0aec0}.error-message{color:#e53e3e;margin-top:8px;font-size:.875rem}.add-to-task-pile{background-color:#6b46c1;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:.75rem;display:flex;align-items:center;gap:4px;cursor:pointer;transition:background-color .2s}.add-to-task-pile:hover{background-color:#553c9a}.add-to-task-pile svg{font-size:.75rem}.ticket-count-badge{display:inline-flex;align-items:center;justify-content:center;background-color:#e53e3e;color:#fff;font-size:.75rem;min-width:1.5rem;height:1.5rem;padding:0 .375rem;border-radius:.75rem;margin-left:.5rem}.generating-title{display:inline-block;position:relative;padding-right:1.5em}.generating-title:after{content:"|";position:absolute;right:0;animation:blink 1s infinite}.typing-subject{display:inline-block;min-width:1ch;min-height:1.2em;position:relative}.cursor{display:inline-block;width:2px;height:1.2em;background-color:#2d3748;margin-left:2px;animation:blink 1s infinite;vertical-align:middle}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.no-tickets{text-align:center;padding:2rem;background:#fff;border-radius:12px;color:#64748b}.navbar-toggle-icon{display:none}.status-button{padding:4px 8px;border-radius:4px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;gap:4px;border:none;transition:all .2s}.status-button.close{background-color:#e53e3e;color:#fff}.status-button.close:hover{background-color:#c53030}.status-button.reopen{background-color:#48bb78;color:#fff}.status-button.reopen:hover{background-color:#38a169}.status-badge{font-size:.75rem;padding:2px 6px;border-radius:4px;font-weight:500}.status-badge.closed{background-color:#e2e8f0;color:#4a5568}.comment-form{display:flex;gap:8px}.comment-form textarea{flex:1;min-height:80px}.comment-buttons{display:flex;flex-direction:column;gap:8px}.comment-buttons button{padding:6px 12px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent;min-width:80px;white-space:nowrap}.comment-buttons button[type=submit]{background-color:#4299e1;color:#fff}.comment-buttons button[type=submit]:hover{background-color:#3182ce}.comment-buttons .close-button{background-color:#f44;color:#fff}.comment-buttons .close-button:hover{background-color:#c00}@media screen and (max-width: 768px){.ticket-nav{flex-direction:column;padding:.75rem}.nav-button{justify-content:flex-start;padding:.75rem}.tickets-grid{grid-template-columns:1fr;gap:1rem}.ticket-form{width:100%;max-width:none;padding:1rem}.form-grid{grid-template-columns:1fr}.ticket-details{padding:1rem}.details-header{flex-direction:column;align-items:flex-start;gap:1rem}.details-actions{width:100%;justify-content:space-between}.comment-form textarea{min-height:80px}.ticket-system{padding:10px}.ticket-form{padding:1rem;margin:0;border-radius:0;box-shadow:none;border-bottom:1px solid #e2e8f0}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.5rem;color:#2d3748}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #e2e8f0;border-radius:.375rem;width:100%;font-size:1rem}.ticket-list{padding:1rem}.ticket{margin-bottom:1rem;border:1px solid #e2e8f0;border-radius:.375rem;background:#fff;overflow:hidden}.ticket-header{padding:1rem;background:#f8f9fa;border-bottom:1px solid #e2e8f0}.ticket-title{font-size:1.1rem;font-weight:600;color:#2d3748;margin:0}.ticket-content{padding:1rem}.ticket-meta{display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem;background:#f8f9fa;border-top:1px solid #e2e8f0}.meta-item{display:flex;align-items:center;gap:.25rem;color:#4a5568;font-size:.875rem}.ticket-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;padding:.75rem 1rem;background:#fff;border-top:1px solid #e2e8f0}.ticket-actions button{padding:.75rem;font-size:.875rem;border-radius:.375rem}}@media screen and (min-width: 769px) and (max-width: 1024px){.tickets-grid{grid-template-columns:repeat(2,1fr)}.ticket-form{width:90%;max-width:600px}}@media screen and (max-width: 480px){.app-nav{padding:.75rem 1rem}.nav-brand{font-size:1rem}.ticket-system{padding:10px}.ticket-card{padding:.75rem}.card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.card-actions{width:100%;justify-content:space-between}.status-badge{padding:.25rem .5rem;font-size:.75rem}.ticket-meta{flex-wrap:wrap;gap:.5rem}.meta-item{font-size:.75rem}.comment-header{flex-direction:column;align-items:flex-start;gap:.25rem}.ticket-form{padding:.75rem}.form-group input,.form-group select,.form-group textarea{padding:.625rem;font-size:.9375rem}.ticket{border-radius:.25rem}.ticket-header{padding:.75rem}.ticket-title{font-size:1rem}.ticket-content{padding:.75rem}.ticket-meta{padding:.625rem .75rem;gap:.5rem}.ticket-actions{padding:.625rem .75rem}.ticket-actions button{padding:.625rem;font-size:.8125rem}}@media screen and (max-width: 768px){.content-container,.content-container.split-view{flex-direction:column;gap:1rem}.form-section{flex:none;border-radius:0;padding:1rem;box-shadow:0 1px 3px #0000001a;overflow-y:visible;margin:-1px;border:1px solid #e2e8f0}.tickets-list{flex:none;overflow-y:visible;padding-right:0;margin-right:0;padding:1rem}.tickets-list h2{margin-bottom:1rem;font-size:1.25rem}.type-selector{margin:-.25rem;padding:.25rem;background:#f8f9fa;border-radius:.5rem}.type-button{padding:.5rem;font-size:.9rem}.ticket-card{margin-bottom:1rem;border:1px solid #e2e8f0}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#2d3748;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:.375rem;font-size:1rem}.form-group textarea{min-height:100px}.form-actions{display:grid;grid-template-columns:1fr;gap:.5rem;margin-top:1rem}.form-actions button{width:100%;padding:.75rem;font-size:1rem}}@media screen and (max-width: 480px){.form-section,.tickets-list{padding:.75rem}.type-button{padding:.4rem;font-size:.85rem}.form-group input,.form-group select,.form-group textarea,.form-actions button{padding:.625rem;font-size:.9375rem}.ticket-card{padding:.75rem}}.technician-ticket-form{max-width:800px;margin:20px auto;padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.technician-ticket-form h2{color:#2d3748;margin-bottom:20px;text-align:center}.technician-ticket-form .form-group{margin-bottom:20px}.technician-ticket-form label{display:block;margin-bottom:8px;color:#4a5568;font-weight:500}.technician-ticket-form input,.technician-ticket-form textarea{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:6px;font-size:16px}.technician-ticket-form textarea{min-height:150px;resize:vertical}.technician-ticket-form .submit-button{width:100%;padding:12px;background-color:#6b46c1;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.technician-ticket-form .submit-button:hover{background-color:#553c9a}.technician-ticket-form .submit-button:disabled{background-color:#a0aec0;cursor:not-allowed}.technician-tickets-container{width:100%;padding:20px;background-color:#f9f9f9}.unauthorized{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f8f9fa}.unauthorized-content{text-align:center;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:400px;width:90%}.unauthorized h1{color:#dc3545;margin-bottom:1rem}.unauthorized p{color:#6c757d;margin-bottom:.5rem}.logout-button{margin-top:1.5rem;padding:.5rem 1.5rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.logout-button:hover{background-color:#5a6268}.staff-layout{min-height:100vh;background-color:#f8f9fa}.staff-header{background-color:#1a202c;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1rem 0;position:sticky;top:0;z-index:1000}.staff-header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.staff-header h1{margin:0;color:#fff;font-size:1.75rem;font-weight:600}.user-controls{display:flex;align-items:center;gap:1rem}.user-controls a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;color:#e2e8f0;text-decoration:none;border-radius:.5rem;font-weight:500;transition:all .2s ease-in-out;background-color:#ffffff1a}.user-controls a:hover{background-color:#fff3;transform:translateY(-1px)}.user-controls a.active{background-color:#4299e1;color:#fff}.user-controls a svg{font-size:1.25rem}.user-controls a span{font-size:.95rem;letter-spacing:.025em}.logout-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;color:#718096;border:1px solid #CBD5E0;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.logout-button:hover{background:#f7fafc;color:#4a5568;border-color:#a0aec0}.logout-button svg{font-size:.875rem}.staff-main{max-width:1200px;margin:2rem auto;padding:0 1rem}.app-nav{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:relative}.nav-links{display:flex;align-items:center;gap:1rem}.nav-brand{display:flex;align-items:center;gap:.5rem;color:#2c3e50;font-size:1.2rem;font-weight:500}.nav-icon{color:inherit;font-size:1.4rem}.app-nav:before,.app-nav:after{display:none}.nav-links:before,.nav-links:after,.nav-brand:before,.nav-brand:after{display:none}.nav-links{list-style:none;padding:0;margin:0}.nav-icon{display:inline-flex;align-items:center}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:#4a5568;text-decoration:none;border-radius:6px;transition:background-color .2s}.nav-link:hover{background:#edf2f7}.nav-link.active{background:#e2e8f0;color:#2d3748}.nav-link-content{position:relative;display:flex;align-items:center;gap:.5rem}.nav-ticket-badge{display:inline-flex;align-items:center;justify-content:center;background-color:#e53e3e;color:#fff;font-size:.75rem;min-width:1.5rem;height:1.5rem;padding:0 .375rem;border-radius:.75rem;margin-left:1rem;font-weight:600}.nav-actions{display:flex;align-items:center;gap:1.5rem}.nav-tickets{display:flex;align-items:center;gap:.5rem;color:#4a5568;font-size:.875rem;font-weight:500}.nav-tickets svg{font-size:1rem}.staff-content{padding:2rem;max-width:1400px;margin:0 auto}@media screen and (max-width: 768px){.staff-layout{padding:0}.staff-header-content{flex-direction:column;align-items:stretch;padding:0;background:#fff;box-shadow:0 2px 4px #0000001a}.nav-links{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0;margin:0;background:#f8f9fa;border-bottom:1px solid #e2e8f0;scrollbar-width:none;-ms-overflow-style:none}.nav-links::-webkit-scrollbar{display:none}.nav-links a{padding:.75rem 1rem;color:#4a5568;text-decoration:none;white-space:nowrap;border-bottom:2px solid transparent;transition:all .2s ease}.nav-links a:hover{color:#2b6cb0}.nav-links a.active{color:#2b6cb0;border-bottom:2px solid #2b6cb0;background:transparent}.user-controls{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff}.staff-main{padding:1rem}}@media screen and (max-width: 480px){.nav-links a,.user-controls{padding:.6rem .8rem;font-size:.9rem}}@media screen and (min-width: 769px) and (max-width: 1024px){.staff-header-content,.staff-main{padding:0 1.5rem}.nav-links{gap:.75rem}}@media screen and (max-width: 480px){.staff-header h1{font-size:1.25rem}.user-email{font-size:.8rem}.logout-button{width:100%;justify-content:center}.nav-brand{font-size:1rem}.nav-icon{font-size:1.2rem}.staff-header-content{padding:.25rem}.nav-links{padding:.25rem 0}.nav-links a{font-size:.85rem;padding:.4rem .6rem}}.task-board{padding:2rem;max-width:1200px;margin:0 auto}.task-board h1{color:#2d3748;margin-bottom:2rem;font-size:1.8rem}.ticket-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;align-items:start}@media screen and (max-width: 768px){.task-board{padding:1rem}.task-board h1{font-size:1.5rem;margin-bottom:1.5rem}.ticket-container{grid-template-columns:1fr;gap:1rem}.ticket-card{margin-bottom:1rem}.card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.card-actions{width:100%;justify-content:flex-start;gap:.5rem}.ticket-meta{flex-wrap:wrap;gap:.5rem}.status-select{width:100%}}@media screen and (min-width: 769px) and (max-width: 1024px){.task-board{padding:1.5rem}.ticket-container{grid-template-columns:repeat(2,1fr)}}@media screen and (max-width: 480px){.task-board h1{font-size:1.25rem;margin-bottom:1rem}.ticket-title{font-size:1rem}.ticket-description{font-size:.9rem}.meta-item{font-size:.8rem}.status-badge{padding:.25rem .5rem;font-size:.75rem}.card-actions button{padding:.5rem .75rem;font-size:.8rem}.ticket-card{padding:.75rem}}@media (max-width: 640px){.task-board{padding:1rem}.ticket-container{grid-template-columns:1fr}}.facilities-board{padding:20px;max-width:1200px;margin:0 auto}.header-title{display:flex;align-items:center}.header-title h1{color:#2d3748;margin:0;font-size:24px}.status-filter{display:flex;gap:10px}.filter-button{padding:8px 16px;border:1px solid #e2e8f0;border-radius:6px;background-color:#fff;color:#4a5568;cursor:pointer;transition:all .2s;font-weight:500}.filter-button:hover{background-color:#f7fafc}.filter-button.active{background-color:#ff6f61;color:#fff;border-color:#ff6f61}.tickets-list{display:flex;flex-direction:column;gap:16px}.no-tickets{text-align:center;padding:40px;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:1.2em;color:#4a5568;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.layout{display:flex;flex-direction:column;height:100vh}.content{flex:1;overflow-y:auto;background-color:#f7fafc}.ticket-filter{display:flex;gap:1rem;margin-bottom:1.5rem;padding:.5rem}.filter-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:2px solid #e2e8f0;border-radius:.5rem;background:#fff;color:#4a5568;font-weight:500;transition:all .2s;cursor:pointer}.filter-button:hover{border-color:#6b46c1;color:#6b46c1}.filter-button.active{background:#6b46c1;border-color:#6b46c1;color:#fff}.filter-button .button-icon{font-size:1.1em}.tech-filter-section{background:#fff;padding:1rem;border-bottom:1px solid #e2e8f0;margin-bottom:1rem;display:flex;flex-direction:column;gap:1rem}.filter-row{display:flex;justify-content:flex-end;align-items:center;margin-bottom:.5rem}.tech-type-selector{display:flex;gap:1rem;justify-content:center;align-items:center}.tech-type-selector .type-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-weight:600;transition:all .2s ease;cursor:pointer}.tech-type-selector .type-button:hover{border-color:#cbd5e0;background:#f7fafc}.tech-type-selector .type-button.active{border-color:#6b46c1;color:#6b46c1;background:#f3f0ff}.tech-type-selector .type-button.active[onclick*=facilities]{border-color:#ff6f61;color:#ff6f61;background:#fff5f5}.tech-type-selector .icon{font-size:1.2rem}.tech-view .tickets-list{padding:1rem}.tech-filter-section .status-filter{display:flex;gap:.5rem;justify-content:flex-end}.tech-filter-section .status-filter .filter-button{padding:.5rem 1rem;border:1px solid #ff6f61;border-radius:6px;background:#fff;color:#ff6f61;font-weight:500;transition:all .2s ease;cursor:pointer}.tech-filter-section .status-filter .filter-button:hover{background:#fff5f5}.tech-filter-section .status-filter .filter-button.active{background:#ff6f61;color:#fff}.ticket-system{padding:2rem;max-width:1200px;margin:0 auto}.ticket-system-header{color:#2d3748;margin-bottom:2rem}.facilities-layout{min-height:100vh;background-color:#f7fafc}.facilities-content{flex:1;padding:2rem}.facilities-layout .app-nav{position:relative;top:auto}.technician-tickets{padding:20px;width:100%;margin:0 auto}.board-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.filters{display:flex;gap:20px;align-items:center;background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-weight:500;color:#4a5568}.filter-group select{padding:8px 16px;border:1px solid #e2e8f0;border-radius:6px;background-color:#fff;color:#4a5568;cursor:pointer;font-size:14px}.tickets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(600px,1fr));gap:1.5rem}.tech-ticket-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;border-top:4px solid #e2e8f0}.tech-ticket-card.type-it{border-top-color:#4299e1}.tech-ticket-card.type-facilities{border-top-color:#48bb78}.ticket-header{padding:1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:flex-start}.ticket-title{flex:1}.ticket-title h3{margin:0;color:#2d3748;font-size:1.1rem;margin-bottom:.5rem}.ticket-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;color:#fff;background-color:#4299e1}.type-facilities .ticket-type-badge{background-color:#48bb78}.status-controls{margin-left:1rem}.status-select{padding:.5rem;border-radius:6px;border:1px solid #e2e8f0;font-weight:500;cursor:pointer}.status-select.status-new{color:#e53e3e;background:#fff5f5;border-color:#fc8181}.status-select.status-in-progress{color:#805ad5;background:#faf5ff;border-color:#b794f4}.status-select.status-completed{color:#38a169;background:#f0fff4;border-color:#68d391}.ticket-content{padding:1.5rem}.ticket-info{margin-bottom:1.5rem}.ticket-description{color:#4a5568;line-height:1.6;margin:0 0 1rem}.ticket-meta{display:flex;gap:1rem;color:#718096;font-size:.875rem}.ticket-comments h4{color:#2d3748;margin:0 0 1rem;font-size:1rem}.comments-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.comment-item{background:#f7fafc;padding:1rem;border-radius:6px}.comment-item.staff-comment{background:#ebf8ff}.comment-header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem}.comment-author{color:#4a5568;font-weight:500}.comment-time{color:#718096}.comment-text{margin:0;color:#4a5568;line-height:1.5}.comment-form{margin-top:1rem}.comment-form textarea{width:100%;min-height:80px;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:.5rem;resize:vertical}.comment-form button{padding:.5rem 1rem;background-color:#4299e1;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.comment-form button:hover{background-color:#3182ce}.no-tickets{grid-column:1 / -1;background:#fff;padding:2rem;text-align:center;border-radius:8px;color:#718096}@media screen and (max-width: 768px){.technician-tickets{padding:.75rem}.filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:.75rem;gap:.75rem;margin-bottom:1rem;scrollbar-width:none;-ms-overflow-style:none}.filters::-webkit-scrollbar{display:none}.filter-group{flex-shrink:0;align-items:center;background:#f7fafc;padding:.4rem .75rem;border-radius:1.5rem;border:1px solid #e2e8f0}.filter-group label{font-size:.85rem;margin-right:.5rem}.filter-group select{font-size:.85rem;padding:.25rem .5rem;border-radius:.75rem;background:#fff;min-width:120px}.tickets-grid{gap:.75rem}.tech-ticket-card{margin:0;border-radius:.75rem}.card-header,.ticket-content{padding:.75rem}.ticket-actions{padding:.75rem;gap:.5rem;flex-wrap:wrap}.ticket-actions button{flex:1;min-width:calc(50% - .25rem);padding:.5rem;font-size:.85rem}}@media screen and (max-width: 480px){.technician-tickets{padding:.5rem}.filters{padding:.5rem;margin-bottom:.75rem}.filter-group{padding:.3rem .6rem}.filter-group label,.filter-group select{font-size:.8rem}.tech-ticket-card{border-radius:.5rem}.ticket-title{font-size:1rem;line-height:1.4}.ticket-meta{font-size:.8rem;gap:.5rem}.ticket-actions button{font-size:.8rem;padding:.4rem}}.tech-stats-container{padding:2rem;max-width:1200px;margin:0 auto}.tech-stats-container h1{color:#2d3748;margin-bottom:2rem;font-size:1.875rem;font-weight:600}.stats-section{margin-bottom:2.5rem}.stats-section h2{color:#4a5568;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.stats-grid.loading{min-height:200px;display:flex;justify-content:center;align-items:center;color:#718096;font-size:1.125rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;align-items:flex-start;gap:1rem;transition:transform .2s ease,box-shadow .2s ease;border:1px solid #e2e8f0;min-height:120px}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.stat-icon{background-color:var(--card-color);color:#fff;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.stat-content{flex-grow:1;min-width:0}.stat-content h3{color:#4a5568;font-size:1rem;font-weight:600;margin:0 0 .75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-details{display:flex;flex-direction:column;gap:.25rem}.stat-name{color:var(--card-color);font-size:1.125rem;font-weight:600;margin:0;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-count{color:#718096;font-size:.875rem;margin:0;white-space:nowrap}.ladder-section{margin-bottom:2rem}.user-ladder{background:var(--background-light);border-radius:10px;padding:1rem;box-shadow:0 2px 5px #0000001a}.ladder-item{display:flex;align-items:center;padding:1rem;margin:.5rem 0;background:#fff;border-radius:8px;transition:transform .2s}.ladder-item:hover{transform:translate(5px)}.user-rank{width:50px;display:flex;flex-direction:column;align-items:center;margin-right:1rem}.crown-icon{font-size:1.5rem;margin-bottom:.5rem}.crown-icon.gold{color:gold}.crown-icon.silver{color:silver}.crown-icon.bronze{color:#cd7f32}.user-info{flex-grow:1}.user-stats{display:flex;gap:1rem;align-items:center}.role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500;margin-left:.5rem}.role-badge svg{font-size:1rem}.role-badge.tech{background-color:#6b46c126;color:#6b46c1}.role-badge.maintenance{background-color:#ff6f6126;color:#ff6f61}.ladder-description{color:#666;font-size:.9rem;margin:-.5rem 0 1rem;font-style:italic}.trophy-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;align-items:flex-start;gap:1rem;transition:transform .2s ease,box-shadow .2s ease;border:1px solid #e2e8f0;min-height:120px}.trophy-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.trophy-icon{background-color:var(--card-color);color:#fff;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.trophy-content{flex-grow:1;min-width:0}.trophy-content h3{color:#4a5568;font-size:1rem;font-weight:600;margin:0 0 .75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trophy-details{display:flex;flex-direction:column;gap:.25rem}.trophy-name{color:var(--card-color);font-size:1.125rem;font-weight:600;margin:0;line-height:1.4}.trophy-detail{color:#718096;font-size:.875rem;margin:0;line-height:1.4}
