*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-secondary: #64748b;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-bg: #f1f5f9;--color-bg-white: #ffffff;--color-sidebar: #1e293b;--color-sidebar-hover: #334155;--color-text-primary: #0f172a;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-text-light: #cbd5e1;--color-border: #e2e8f0;--color-border-dark: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--radius-sm: .25rem;--radius: .375rem;--radius-lg: .5rem;--radius-xl: .75rem}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-bg);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:16rem;background:var(--color-sidebar);color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width .3s ease}.sidebar.collapsed{width:4.5rem}.sidebar-header{padding:1rem;border-bottom:1px solid var(--color-sidebar-hover);position:relative}.sidebar.collapsed .sidebar-header{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem}.sidebar-brand{display:flex;align-items:flex-start;gap:.75rem;padding-right:2rem}.sidebar-brand-text{display:flex;flex-direction:column;min-width:0}.sidebar-brand-text h1{font-size:1.125rem;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-brand-text p{font-size:.75rem;color:var(--color-text-muted);margin-top:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-brand-collapsed{display:flex;justify-content:center;margin-top:.25rem}.sidebar-logo-placeholder{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-sidebar-hover);border-radius:6px;font-size:.875rem;font-weight:600;color:var(--color-text-light)}.sidebar-toggle{position:absolute;top:1rem;right:.5rem;background:transparent;border:none;color:var(--color-text-light);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:background-color .15s,color .15s}.sidebar-toggle:hover{background:var(--color-sidebar-hover);color:#fff}.sidebar.collapsed .sidebar-toggle{position:static;margin-bottom:.5rem}.sidebar-logo{width:40px;height:40px;min-width:40px;object-fit:contain;border-radius:6px}.sidebar-logo-collapsed{width:36px;height:36px;object-fit:contain;border-radius:6px}.sidebar-nav{flex:1;padding:.75rem;overflow-y:auto}.nav-section{margin-bottom:1rem}.nav-section-title{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:.5rem .75rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;margin-bottom:.25rem;border-radius:var(--radius);color:var(--color-text-light);text-decoration:none;font-size:.875rem;cursor:pointer;transition:background-color .15s,color .15s;white-space:nowrap}.sidebar.collapsed .nav-item{justify-content:center;padding:.5rem}.nav-item:hover{background:var(--color-sidebar-hover);color:#fff}.nav-item.active{background:var(--color-sidebar-hover);color:#fff;font-weight:500}.nav-item svg{width:1.25rem;height:1.25rem;flex-shrink:0}.sidebar-footer{padding:1rem;border-top:1px solid var(--color-sidebar-hover)}.sidebar.collapsed .sidebar-footer{padding:.75rem .5rem}.user-info{display:flex;align-items:center;gap:.75rem}.sidebar.collapsed .user-info{flex-direction:column;gap:.5rem}.user-avatar{width:2.25rem;height:2.25rem;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0;overflow:hidden}.user-avatar-img{width:100%;height:100%;object-fit:cover}.user-details{flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--color-text-muted)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{background:var(--color-bg-white);border-bottom:1px solid var(--color-border);padding:.75rem 1.5rem;flex-shrink:0}.topbar-content{display:flex;justify-content:space-between;align-items:center}.topbar-left{display:flex;align-items:center;gap:1rem}.topbar-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.topbar-right{display:flex;align-items:center;gap:.75rem}.page-content{flex:1;padding:1.5rem;overflow-y:auto}.page-content:has(.ticket-detail-layout),.page-content-ticket-detail{overflow-y:hidden}.page-content-list{display:flex;flex-direction:column;overflow:hidden}.page-content-list>*{flex-shrink:0}.page-content-list>.card{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.page-content-list .table-container{flex:1;overflow-y:auto}.page-content-list .table thead th{position:sticky;top:0;z-index:1;background:var(--color-bg)}.card{background:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--color-border)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.card-body{padding:1.25rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow);border:1px solid var(--color-border)}.stat-label{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.5rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-text-primary)}.stat-change{font-size:.75rem;margin-top:.25rem}.stat-change.positive{color:var(--color-success)}.stat-change.negative{color:var(--color-danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:background-color .15s,box-shadow .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-bg);color:var(--color-text-primary);border:1px solid var(--color-border-dark)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg)}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.icon-btn{padding:.5rem;background:transparent;border:none;cursor:pointer;border-radius:var(--radius);color:var(--color-text-secondary);position:relative}.icon-btn:hover{background:var(--color-bg)}.icon-btn svg{width:1.25rem;height:1.25rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-primary);margin-bottom:.375rem}.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--color-border-dark);border-radius:var(--radius);background:var(--color-bg-white);color:var(--color-text-primary);transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-danger)}.form-error{font-size:.75rem;color:var(--color-danger);margin-top:.25rem}.form-textarea{min-height:6rem;resize:vertical}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.table th{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg)}.table tbody tr:hover{background:var(--color-bg)}.table tbody tr{cursor:pointer}.table td{font-size:.875rem}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge-primary{background:#3b82f61a;color:var(--color-primary)}.badge-success{background:#22c55e1a;color:var(--color-success)}.badge-warning{background:#f59e0b1a;color:var(--color-warning)}.badge-danger{background:#ef44441a;color:var(--color-danger)}.badge-secondary{background:var(--color-bg);color:var(--color-text-secondary)}.release-status-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px}.release-status-draft{background:#6b72801a;color:#6b7280}.release-status-planned{background:#3b82f61a;color:var(--color-info, #3b82f6)}.release-status-released{background:#10b9811a;color:#10b981}.release-status-cancelled{background:#ef44441a;color:var(--color-danger)}.ticket-release-link{cursor:pointer;transition:opacity .15s}.ticket-release-link:hover{opacity:.75}.priority-low{background:#22c55e1a;color:#16a34a}.priority-normal{background:#3b82f61a;color:#2563eb}.priority-high{background:#f59e0b1a;color:#d97706}.priority-urgent{background:#f973161a;color:#ea580c}.priority-critical{background:#ef44441a;color:#dc2626}.status-queue{background:#64748b1a;color:#475569}.status-in_progress{background:#3b82f61a;color:#2563eb}.status-pending{background:#f59e0b1a;color:#d97706}.status-resolved{background:#22c55e1a;color:#16a34a}.status-open{background:#3b82f61a;color:#2563eb}.status-released{background:#10b9811a;color:#10b981}.status-closed{background:#64748b1a;color:#64748b}.search-input-wrapper{position:relative}.search-input-wrapper input{padding-left:2.5rem}.search-input-wrapper svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:var(--color-text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a)}.login-card{width:100%;max-width:24rem;background:var(--color-bg-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:2rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.5rem}.login-header p{color:var(--color-text-secondary);font-size:.875rem}.login-error{background:#ef44441a;color:var(--color-danger);padding:.75rem;border-radius:var(--radius);font-size:.875rem;margin-bottom:1rem;text-align:center}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a);padding:1rem}.auth-card{width:100%;max-width:24rem;background:var(--color-bg-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:2rem}.pagination{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-top:1rem}.pagination-btn{padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--color-border);background:var(--color-bg-white);border-radius:var(--radius);cursor:pointer}.pagination-btn:hover:not(:disabled){background:var(--color-bg)}.pagination-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50}.modal,.modal-content{background:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:32rem;max-height:90vh;overflow-y:auto}.modal-content{padding:1.5rem}.modal.modal-lg{max-width:48rem}.modal.modal-xl{max-width:64rem}.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.125rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.75rem}@media(max-width:640px){.modal,.modal-content{max-width:calc(100vw - 1rem)!important;margin:0 .5rem;max-height:95vh}.modal.modal-lg,.modal.modal-xl{max-width:calc(100vw - 1rem)}.modal-header,.modal-footer{padding:.75rem 1rem}.modal-body{padding:1rem}.modal-title{font-size:1rem}}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.mobile-menu-btn{display:none;position:fixed;top:.75rem;left:.75rem;z-index:60;background:var(--color-sidebar);color:#fff;border:none;border-radius:var(--radius);padding:.5rem;cursor:pointer;box-shadow:var(--shadow-md)}.mobile-menu-btn:hover{background:var(--color-sidebar-hover)}.mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:35}@media(max-width:768px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.mobile-overlay{display:block}.sidebar{position:fixed;left:-16rem;height:100vh;height:100dvh;z-index:40;transition:left .3s ease}.sidebar.mobile-open{left:0}.sidebar.collapsed{left:-16rem}.sidebar.collapsed.mobile-open{left:0;width:16rem}.sidebar-toggle{display:none}.stats-grid{grid-template-columns:1fr}.topbar{padding-left:4rem}.ticket-detail-layout{flex-direction:column;height:auto;min-height:auto}.ticket-info-column{overflow-y:visible}.ticket-chat-column{width:100%}.ticket-chat-card{height:auto;max-height:400px}.call-video-tile-self{width:120px;bottom:70px;right:12px}.call-chat-panel{width:100%;max-height:250px;border-left:none;border-top:1px solid rgba(255,255,255,.1)}.call-control-btn{width:40px;height:40px}.incoming-call-modal{min-width:unset;width:calc(100vw - 2rem);max-width:300px}}.empty-state{text-align:center;padding:3rem}.empty-state svg{width:4rem;height:4rem;color:var(--color-text-muted);margin-bottom:1rem}.empty-state h3{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.5rem}.empty-state p{font-size:.875rem;color:var(--color-text-secondary)}.spinner{width:2rem;height:2rem;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:100}.ticket-detail-layout{display:flex;gap:1.5rem;height:calc(100vh - 7rem);height:calc(100dvh - 7rem);min-height:400px}.ticket-info-column{flex:1;min-width:0;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;padding-right:.25rem}.ticket-info-column::-webkit-scrollbar{width:6px}.ticket-info-column::-webkit-scrollbar-track{background:transparent}.ticket-info-column::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.ticket-info-column::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.ticket-chat-column{width:24rem;flex-shrink:0;display:flex;flex-direction:column;min-height:0;height:100%}.ticket-chat-card{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.ticket-chat-card .card-header{flex-shrink:0;padding:.75rem 1rem}.ticket-chat-body{flex:1 1 0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.ticket-chat-body .chat-container{flex:1;overflow-y:auto;padding:1rem;min-height:0;max-height:none;display:flex;flex-direction:column;gap:.75rem}.chat-spacer{flex:1}.ticket-chat-body .chat-input-container{flex-shrink:0;padding:.75rem 1rem;border-top:1px solid var(--color-border);background:var(--color-bg-card)}.ticket-chat-body .chat-actions{margin-bottom:0;padding-bottom:0}.ticket-meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem .75rem}.ticket-meta-item{display:flex;flex-direction:column;gap:.125rem;padding:.25rem 0}.ticket-meta-label{font-size:.625rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.025em}.ticket-meta-value{font-size:.8125rem;font-weight:500;color:var(--color-text-primary)}.form-select-sm{width:100%;padding:.25rem .5rem;font-size:.8125rem;border-radius:.375rem}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);text-align:center;padding:2rem}.ticket-detail{display:grid;grid-template-columns:1fr 20rem;gap:1.5rem}.ticket-main{display:flex;flex-direction:column;gap:1.5rem}.ticket-sidebar{display:flex;flex-direction:column;gap:1rem}.chat-container{display:flex;flex-direction:column;gap:1rem;max-height:500px;overflow-y:auto;padding:.5rem;scroll-behavior:smooth}.chat-message{display:flex;flex-direction:column;max-width:80%}.chat-message.own{align-self:flex-end}.chat-message.other{align-self:flex-start}.chat-bubble{padding:.75rem 1rem;border-radius:1rem;position:relative;word-wrap:break-word}.chat-message.own .chat-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:.25rem}.chat-message.other .chat-bubble{background:#e2e8f0;color:var(--color-text-primary);border-bottom-left-radius:.25rem;border:1px solid var(--color-border-dark)}.chat-message.internal .chat-bubble{background:#f59e0b26;color:var(--color-text-primary);border:1px dashed var(--color-warning)}.chat-message.own.internal .chat-bubble{background:#f59e0b40}.chat-author{font-size:.75rem;font-weight:600;margin-bottom:.25rem;display:flex;align-items:center;gap:.375rem}.chat-message.own .chat-author{justify-content:flex-end;color:var(--color-text-secondary)}.chat-message.other .chat-author{color:var(--color-text-secondary)}.chat-text{font-size:.875rem;line-height:1.5;white-space:pre-wrap}.chat-meta{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;font-size:.6875rem;color:var(--color-text-muted)}.chat-message.own .chat-meta{justify-content:flex-end}.internal-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.625rem;font-weight:600;color:var(--color-warning);background:#f59e0b1a;padding:.125rem .375rem;border-radius:.25rem;text-transform:uppercase}.reply-btn{opacity:0;background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.125rem;border-radius:.25rem;transition:opacity .15s,color .15s;display:inline-flex;align-items:center}.chat-message:hover .reply-btn{opacity:1}.reply-btn:hover{color:var(--color-primary)}.reply-preview{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-secondary);border-left:3px solid var(--color-primary);border-top:1px solid var(--color-border);font-size:.8125rem;color:var(--color-text-secondary)}.reply-preview-content{display:flex;align-items:center;gap:.375rem;overflow:hidden;min-width:0}.reply-preview-content span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-quote{font-size:.75rem;color:var(--color-text-muted);border-left:2px solid var(--color-border);padding:.25rem .5rem;margin-bottom:.375rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-quote-author{font-weight:600}.chat-input-container{display:flex;flex-direction:column;gap:.5rem}.chat-input-wrapper{display:flex;gap:.5rem;align-items:flex-end}.chat-input{flex:1;min-height:2.5rem;max-height:8rem;padding:.625rem 1rem;border:1px solid var(--color-border);border-radius:1.25rem;font-size:.875rem;resize:none;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.chat-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f61a}.chat-input::placeholder{color:var(--color-text-muted)}.chat-send-btn{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--color-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s,transform .1s;flex-shrink:0}.chat-send-btn:hover:not(:disabled){background:var(--color-primary-dark)}.chat-send-btn:active:not(:disabled){transform:scale(.95)}.chat-send-btn:disabled{background:var(--color-text-muted);cursor:not-allowed}.chat-actions{display:flex;justify-content:space-between;align-items:center}.chat-options{display:flex;align-items:center;gap:1rem}.internal-toggle{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.internal-toggle input{width:1rem;height:1rem;accent-color:var(--color-warning)}.internal-toggle:hover{color:var(--color-text-primary)}.comment-list{display:flex;flex-direction:column;gap:1rem}.comment{padding:1rem;background:var(--color-bg);border-radius:var(--radius)}.comment.internal{background:#f59e0b1a;border-left:3px solid var(--color-warning)}.comment-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.comment-author{font-weight:500;font-size:.875rem}.comment-date{font-size:.75rem;color:var(--color-text-secondary)}.comment-content{font-size:.875rem;line-height:1.6}.filters-bar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-select{width:auto;min-width:10rem;padding-right:2rem}.search-input-wrapper{position:relative;display:inline-flex;align-items:center}.search-input{min-width:12rem;padding-right:1.75rem!important;padding-left:.75rem!important}.search-clear-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;padding:0;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;line-height:1;z-index:1}.search-clear-btn:hover{color:var(--color-text)}.date-input-wrapper{display:inline-flex;align-items:center;gap:.5rem}.date-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500;white-space:nowrap}.date-input{min-width:8.5rem}.date-input::-webkit-calendar-picker-indicator{opacity:.6;cursor:pointer}.date-input:hover::-webkit-calendar-picker-indicator{opacity:1}.notification-badge{position:absolute;top:0;right:0;width:.5rem;height:.5rem;background:var(--color-danger);border-radius:50%}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:12rem;z-index:20}.dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;font-size:.875rem;color:var(--color-text-primary);background:none;border:none;cursor:pointer;text-align:left}.dropdown-item:hover{background:var(--color-bg)}.dropdown-divider{height:1px;background:var(--color-border);margin:.25rem 0}@media(max-width:1024px){.ticket-detail{grid-template-columns:1fr}.ticket-detail-layout{flex-direction:column;height:auto;min-height:auto}.ticket-info-column{overflow-y:visible}.ticket-chat-column{width:100%}.ticket-chat-card{height:auto;max-height:500px}.ticket-meta-grid{grid-template-columns:1fr}}.history-timeline{position:relative}.history-item{position:relative;padding-left:1.5rem;padding-bottom:1.25rem}.history-item:last-child{padding-bottom:0}.history-dot{position:absolute;left:0;top:.25rem;width:.625rem;height:.625rem;background:var(--color-primary);border-radius:50%;z-index:1}.history-line{position:absolute;left:.25rem;top:.875rem;width:2px;height:calc(100% - .5rem);background:var(--color-border)}.history-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.375rem;padding:.75rem}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:.5rem}.history-user{font-weight:500;font-size:.875rem;color:var(--color-text-primary)}.history-date{font-size:.75rem;color:var(--color-text-secondary)}.history-change{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem}.history-comment{margin-top:.5rem;font-size:.8125rem;color:var(--color-text-secondary);font-style:italic}.attachment-list{display:flex;flex-direction:column;gap:.5rem}.attachment-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--color-bg);border-radius:var(--radius);border:1px solid var(--color-border)}.attachment-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--color-primary);color:#fff;border-radius:var(--radius);flex-shrink:0}.attachment-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.attachment-meta{font-size:.6875rem;color:var(--color-text-muted)}.attachment-name{font-size:.875rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-size{font-size:.75rem;color:var(--color-text-secondary)}.pdf-modal-content{display:flex;flex-direction:column;gap:1rem}.pdf-mode-selector{display:flex;gap:.5rem;border-bottom:1px solid var(--color-border);padding-bottom:.75rem}.pdf-mode-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;font-size:.8125rem;transition:all .15s}.pdf-mode-btn:hover{background:var(--color-bg)}.pdf-mode-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pdf-setting-selector{margin-top:.25rem}.pdf-setting-row{display:flex;gap:.5rem;align-items:center}.pdf-setting-row .form-select{flex:1}.pdf-email-fields{display:flex;flex-direction:column;gap:.75rem}.pdf-modal-actions{display:flex;gap:.5rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--color-border)}.pdf-success{display:flex;align-items:center;gap:.375rem;color:#16a34a;font-weight:500;font-size:.875rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pdf-settings-manager{display:flex;flex-direction:column;gap:.75rem}.pdf-settings-header{display:flex;justify-content:space-between;align-items:center}.pdf-settings-header h4{margin:0;font-size:.9375rem}.pdf-settings-count{font-size:.75rem;color:var(--color-text-secondary)}.pdf-settings-empty{padding:1rem;text-align:center;color:var(--color-text-muted);font-style:italic;font-size:.8125rem}.pdf-settings-list{display:flex;flex-direction:column;gap:.375rem}.pdf-setting-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.pdf-setting-name{font-size:.8125rem;font-weight:500}.pdf-setting-actions{display:flex;gap:.25rem}.pdf-settings-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem}.pdf-setting-form{display:flex;flex-direction:column;gap:.75rem}.pdf-setting-form h5{margin:0;font-size:.875rem}.pdf-setting-filters-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.pdf-setting-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem}.pdf-setting-form-actions{display:flex;gap:.5rem;justify-content:flex-end;padding-top:.5rem}.protocol-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem 1.25rem}.protocol-section .section-title{margin:0 0 .75rem;font-size:.9375rem}.protocol-actions{display:flex;flex-direction:column;gap:.75rem}.protocol-email-section{padding-top:.5rem;border-top:1px solid var(--color-border)}.protocol-email-field{margin-bottom:.5rem}.protocol-email-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.25rem}.protocol-email-field .form-textarea{min-height:4rem;font-size:.8125rem}.email-chips-container{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center}.email-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:var(--color-primary-light, #EEF2FF);color:var(--color-primary, #4F46E5);border-radius:999px;font-size:.75rem;font-weight:500;white-space:nowrap}.email-chip-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:.875rem;line-height:1;padding:0 .125rem;opacity:.7}.email-chip-remove:hover{opacity:1}.email-chip-add{flex:0 0 auto;min-width:160px;max-width:220px}.form-select-sm,.form-input-sm{padding:.375rem .5rem;font-size:.8125rem}.audit-timeline{position:relative;max-height:400px;overflow-y:auto;padding:.75rem 1rem}.audit-timeline::-webkit-scrollbar{width:5px}.audit-timeline::-webkit-scrollbar-track{background:transparent}.audit-timeline::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.audit-item{position:relative;padding-left:1.5rem;padding-bottom:1rem}.audit-item:last-child{padding-bottom:0}.audit-dot{position:absolute;left:0;top:.25rem;width:.5rem;height:.5rem;border-radius:50%;background:var(--color-primary);z-index:1}.audit-dot[data-type=created]{background:var(--color-success, #16a34a)}.audit-dot[data-type=status]{background:var(--color-primary)}.audit-dot[data-type=assignment]{background:var(--color-warning, #f59e0b)}.audit-dot[data-type=field_change]{background:var(--color-text-muted)}.audit-dot[data-type=comment]{background:#3b82f6}.audit-dot[data-type=attachment]{background:#8b5cf6}.audit-line{position:absolute;left:.1875rem;top:.75rem;width:2px;height:calc(100% - .25rem);background:var(--color-border)}.audit-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.375rem;padding:.5rem .75rem}.audit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;gap:.5rem}.audit-user{font-weight:500;font-size:.8125rem;color:var(--color-text-primary)}.audit-date{font-size:.6875rem;color:var(--color-text-secondary);white-space:nowrap}.audit-change{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem;font-size:.8125rem}.audit-label{font-weight:500;color:var(--color-text-secondary)}.audit-old{color:var(--color-danger, #dc2626);text-decoration:line-through;opacity:.7}.audit-arrow{color:var(--color-text-muted);margin:0 .125rem}.audit-new{color:var(--color-success, #16a34a);font-weight:500}.audit-comment{margin-top:.25rem;font-size:.75rem;color:var(--color-text-secondary);font-style:italic}.audit-comment-preview{font-size:.75rem;color:var(--color-text-secondary);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:block}.dependency-list{display:flex;flex-direction:column;gap:.375rem}.dependency-direction-label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.025em;margin-bottom:.25rem}.linked-request-item{padding:.625rem .75rem;border-bottom:1px solid var(--color-border)}.linked-request-item:last-child{border-bottom:none}.linked-request-header{display:flex;align-items:center;gap:.5rem;font-size:.8125rem}.linked-request-number{font-weight:600;color:var(--color-primary);cursor:pointer;white-space:nowrap}.linked-request-number:hover{text-decoration:underline}.linked-request-subject{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary)}.linked-request-date{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem}.linked-request-description{margin-top:.375rem;font-size:.75rem;color:var(--color-text-secondary);line-height:1.4;white-space:pre-wrap;max-height:4.2em;overflow:hidden}.desc-entry-form{padding:.75rem;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:.5rem}.desc-entry-list{display:flex;flex-direction:column}.desc-entry-item{padding:.75rem;border-bottom:1px solid var(--color-border)}.desc-entry-item:last-child{border-bottom:none}.desc-entry-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem;font-size:.75rem}.desc-entry-user{font-weight:600;color:var(--color-text-primary)}.desc-entry-date{color:var(--color-text-muted)}.desc-entry-text{white-space:pre-wrap;line-height:1.6;font-size:.875rem;color:var(--color-text-primary)}.ext-ref-form{display:flex;flex-direction:column;gap:.375rem;padding:.75rem;border-bottom:1px solid var(--color-border)}.ext-ref-list{display:flex;flex-direction:column}.ext-ref-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid var(--color-border);font-size:.8125rem}.ext-ref-item:last-child{border-bottom:none}.ext-ref-header{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.ext-ref-provider{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:.125rem .375rem;border-radius:var(--radius);background:#6366f11a;background:color-mix(in srgb,var(--color-primary) 12%,transparent);color:var(--color-primary);white-space:nowrap}.ext-ref-id{font-weight:600;color:var(--color-primary);white-space:nowrap}a.ext-ref-id:hover{text-decoration:underline}.ext-ref-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-secondary)}.ext-ref-actions{display:flex;align-items:center;gap:.375rem;margin-left:.5rem}.ext-ref-status{font-size:.6875rem;padding:.125rem .375rem;border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-secondary);white-space:nowrap}.ext-ref-search-results{display:flex;flex-direction:column;max-height:200px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius)}.ext-ref-search-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;border:none;border-bottom:1px solid var(--color-border);background:transparent;cursor:pointer;text-align:left;font-size:.8125rem;color:var(--color-text-primary);width:100%}.ext-ref-search-item:last-child{border-bottom:none}.ext-ref-search-item:hover{background:var(--color-surface)}.ext-ref-search-id{font-weight:600;color:var(--color-primary);white-space:nowrap;font-size:.75rem}.ext-ref-search-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ext-ref-search-status{font-size:.6875rem;padding:.0625rem .375rem;border-left:2px solid;color:var(--color-text-secondary);white-space:nowrap}.dependency-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:.8125rem}.dependency-ticket-link{font-weight:600;color:var(--color-primary);cursor:pointer;white-space:nowrap}.dependency-ticket-link:hover{text-decoration:underline}.dependency-customer-ref{color:var(--color-text-secondary);white-space:nowrap;font-size:.75rem}.dependency-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary)}.dependency-date{color:var(--color-text-muted);white-space:nowrap;font-size:.75rem}.dependency-remove-btn{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.125rem;border-radius:.25rem;display:flex;align-items:center;transition:color .15s}.dependency-remove-btn:hover{color:var(--color-danger)}.dependency-search-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-height:280px;display:flex;flex-direction:column;z-index:20;overflow:hidden}.dependency-search-dropdown-results{overflow-y:auto;flex:1;min-height:0}.dependency-search-footer{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-top:1px solid var(--color-border);background:var(--color-bg)}.dependency-search-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;font-size:.8125rem;background:none;border:none;cursor:pointer;text-align:left}.dependency-search-item:hover{background:var(--color-bg)}.dependency-search-item.selected{background:#3b82f614;background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.topbar-icon-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:6px;border-radius:6px;position:relative;display:flex;align-items:center;transition:color .2s,background .2s}.topbar-icon-btn:hover{color:var(--color-primary);background:#3b82f614;background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.messenger-unread-badge{position:absolute;top:-2px;right:-4px;background:var(--color-danger, #ef4444);color:#fff;font-size:10px;font-weight:600;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.nav-badge{background:var(--color-danger, #ef4444);color:#fff;font-size:10px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;margin-left:auto}.messenger-sidebar-backdrop{position:fixed;inset:0;background:#0000004d;z-index:999}.messenger-sidebar{position:fixed;top:0;right:0;width:400px;max-width:100vw;height:100vh;background:var(--color-bg-card, #fff);box-shadow:-4px 0 20px #00000026;z-index:1000;display:flex;flex-direction:column;animation:slideInRight .2s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.messenger-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-border);min-height:56px}.messenger-sidebar-header-left{display:flex;align-items:center;gap:8px}.messenger-sidebar-back-btn,.messenger-sidebar-close-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.messenger-sidebar-back-btn:hover,.messenger-sidebar-close-btn:hover{color:var(--color-text);background:var(--color-bg)}.messenger-sidebar-title{font-size:16px;font-weight:600;color:var(--color-text)}.messenger-sidebar-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.conversation-list{display:flex;flex-direction:column;height:100%}.conversation-list-actions{display:flex;gap:8px;padding:12px 16px}.conversation-search{flex:1;display:flex;align-items:center;gap:8px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;padding:6px 12px}.conversation-search input{flex:1;border:none;background:none;outline:none;font-size:13px;color:var(--color-text)}.conversation-items{flex:1;overflow-y:auto}.conversation-item{display:flex;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--color-border)}.conversation-item:hover{background:var(--color-bg)}.conversation-item-unread{background:#3b82f60a;background:color-mix(in srgb,var(--color-primary) 4%,transparent)}.conversation-item-icon{width:36px;height:36px;border-radius:50%;background:#3b82f61f;background:color-mix(in srgb,var(--color-primary) 12%,transparent);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.conversation-item-content{flex:1;min-width:0}.conversation-item-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.conversation-item-title{font-weight:500;font-size:14px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item-time{font-size:11px;color:var(--color-text-secondary);flex-shrink:0}.conversation-item-preview{display:flex;align-items:center;gap:4px;margin-top:2px}.conversation-item-last-message{font-size:13px;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.conversation-ticket-icon{color:var(--color-primary);flex-shrink:0}.conversation-unread-badge{background:var(--color-primary);color:#fff;font-size:11px;font-weight:600;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.conversation-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;color:var(--color-text-secondary);gap:8px}.conversation-list-loading{padding:24px;text-align:center;color:var(--color-text-secondary)}.chat-view{display:flex;flex-direction:column;height:100%}.chat-header{padding:12px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:8px}.chat-header-actions{display:flex;gap:4px}.chat-call-btn{background:none;border:1px solid var(--color-border);border-radius:8px;padding:6px 8px;cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center;transition:all .15s}.chat-call-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.chat-header-info h4{font-size:14px;font-weight:600;margin-bottom:2px}.chat-header-participants{font-size:12px;color:var(--color-text-secondary)}.chat-messages{flex:1;overflow-y:auto;padding:16px}.chat-messages-list{display:flex;flex-direction:column;gap:4px}.chat-messages-loading,.chat-messages-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-secondary);font-size:14px}.message-bubble{max-width:80%;padding:8px 12px;border-radius:12px;background:var(--color-bg);align-self:flex-start;position:relative}.message-bubble-own{align-self:flex-end;background:#3b82f61f;background:color-mix(in srgb,var(--color-primary) 12%,transparent)}.message-sender{font-size:11px;font-weight:600;color:var(--color-primary);margin-bottom:2px}.message-content{font-size:14px;color:var(--color-text);white-space:pre-wrap;word-break:break-word}.message-time{font-size:10px;color:var(--color-text-secondary);text-align:right;margin-top:2px}.message-edited{font-size:10px;color:var(--color-text-secondary);font-style:italic}.message-deleted{font-style:italic;color:var(--color-text-secondary);padding:8px 12px}.message-reply-preview{font-size:12px;padding:4px 8px;margin-bottom:4px;border-left:2px solid var(--color-primary);background:#3b82f60d;background:color-mix(in srgb,var(--color-primary) 5%,transparent);border-radius:2px}.message-reply-sender{font-weight:600;font-size:11px;color:var(--color-primary)}.message-reply-text{color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-attachments{margin-top:4px;display:flex;flex-direction:column;gap:4px}.message-attachment-link{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--color-primary);text-decoration:none}.message-attachment-link:hover{text-decoration:underline}.message-input-container{border-top:1px solid var(--color-border);padding:8px 12px}.message-input-reply{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--color-text-secondary);padding:4px 8px;background:var(--color-bg);border-radius:6px;margin-bottom:8px}.message-input-reply button{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:2px}.message-input-attachments{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.message-input-attachment-chip{display:flex;align-items:center;gap:4px;font-size:12px;padding:2px 8px;background:var(--color-bg);border-radius:12px;border:1px solid var(--color-border)}.message-input-attachment-chip button{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:0;display:flex}.message-input-row{display:flex;align-items:flex-end;gap:8px}.message-input-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center}.message-input-btn:hover{color:var(--color-primary);background:#3b82f614;background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.message-input-send{color:var(--color-primary)}.message-input-send:disabled{color:var(--color-text-secondary);cursor:not-allowed}.message-input-textarea{flex:1;border:1px solid var(--color-border);border-radius:8px;padding:8px 12px;font-size:14px;resize:none;outline:none;background:var(--color-bg);color:var(--color-text);max-height:120px;font-family:inherit}.message-input-textarea:focus{border-color:var(--color-primary)}.typing-indicator{display:flex;align-items:center;gap:6px;padding:4px 16px;font-size:12px;color:var(--color-text-secondary)}.typing-dots{display:flex;gap:2px}.typing-dots span{width:4px;height:4px;border-radius:50%;background:var(--color-text-secondary);animation:typingBounce 1.2s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}}.participant-list-panel{border-top:1px solid var(--color-border);background:var(--color-bg-card, #fff)}.participant-list-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--color-border)}.participant-list-header h4{font-size:13px;font-weight:600}.participant-list-header button{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:2px}.participant-list-items{max-height:200px;overflow-y:auto}.participant-list-item{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;font-size:13px}.participant-info{display:flex;align-items:center;gap:6px}.participant-name{font-weight:500}.participant-you{color:var(--color-text-secondary);font-weight:400;font-size:12px}.participant-remove{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:4px;border-radius:4px}.participant-remove:hover{color:var(--color-danger, #ef4444);background:#ef444414;background:color-mix(in srgb,var(--color-danger, #ef4444) 8%,transparent)}.messenger-new-modal{max-width:480px}.messenger-new-type-toggle{display:flex;gap:8px;margin-bottom:12px}.messenger-user-list{max-height:300px;overflow-y:auto;border:1px solid var(--color-border);border-radius:8px;margin-top:12px}.messenger-user-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--color-border)}.messenger-user-item:last-child{border-bottom:none}.messenger-user-item:hover{background:var(--color-bg)}.messenger-user-item.selected{background:#3b82f614;background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.messenger-user-info{display:flex;flex-direction:column}.messenger-user-name{font-size:14px;font-weight:500}.messenger-user-email{font-size:12px;color:var(--color-text-secondary)}.messenger-fullpage{display:flex;flex:1;overflow:hidden;border:1px solid var(--color-border);border-radius:8px;margin:16px;background:var(--color-bg-card, #fff)}.messenger-fullpage-sidebar{width:320px;border-right:1px solid var(--color-border);overflow:hidden}.messenger-fullpage-chat{flex:1;display:flex;flex-direction:column;overflow:hidden}.messenger-fullpage-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-text-secondary);gap:12px}.messenger-unavailable{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:var(--color-text-secondary);gap:12px}.incoming-call-backdrop{position:fixed;inset:0;background:#0009;z-index:2000;display:flex;align-items:center;justify-content:center}.incoming-call-modal{background:var(--color-bg-card, #fff);border-radius:16px;padding:32px;text-align:center;min-width:300px;box-shadow:0 20px 60px #0000004d;animation:pulseIn .3s ease}@keyframes pulseIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.incoming-call-avatar{width:64px;height:64px;border-radius:50%;background:#3b82f61f;background:color-mix(in srgb,var(--color-primary) 12%,transparent);display:flex;align-items:center;justify-content:center;color:var(--color-primary);margin:0 auto 16px;animation:callPulse 1.5s infinite}@keyframes callPulse{0%,to{box-shadow:0 0 #3b82f64d;box-shadow:0 0 color-mix(in srgb,var(--color-primary) 30%,transparent)}50%{box-shadow:0 0 0 12px transparent}}.incoming-call-name{font-size:20px;font-weight:600;margin-bottom:4px}.incoming-call-type{color:var(--color-text-secondary);font-size:14px;margin-bottom:24px}.incoming-call-actions{display:flex;gap:24px;justify-content:center}.incoming-call-reject,.incoming-call-accept{width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .2s}.incoming-call-reject{background:var(--color-danger, #ef4444)}.incoming-call-accept{background:#22c55e}.incoming-call-reject:hover,.incoming-call-accept:hover{transform:scale(1.1)}.call-overlay{position:fixed;inset:0;background:#1a1a2e;z-index:1500;display:flex;flex-direction:column;color:#fff}.call-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#0000004d}.call-overlay-title{font-size:16px;font-weight:500}.call-timer{font-size:14px;font-variant-numeric:tabular-nums;color:#ffffffb3}.call-pip-btn{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:6px;border-radius:6px}.call-pip-btn:hover{background:#ffffff1a;color:#fff}.call-overlay-content{flex:1;display:flex;overflow:hidden}.call-video-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px;padding:16px;align-content:center}.call-video-tile{background:#16213e;border-radius:12px;aspect-ratio:16/9;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.call-video-tile-main{width:100%;max-height:70vh;aspect-ratio:16/9}.call-video-tile-self{position:absolute;bottom:80px;right:24px;width:200px;aspect-ratio:16/9;border:2px solid rgba(255,255,255,.3);border-radius:12px;z-index:10}.call-video-element{width:100%;height:100%;object-fit:cover;border-radius:12px}.call-video-avatar{width:64px;height:64px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600}.call-video-name{margin-top:8px;font-size:13px;color:#ffffffe6}.call-video-status{position:absolute;bottom:8px;right:8px;display:flex;gap:4px;color:#fff9}.call-video-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:#ffffff80}.call-chat-panel{width:320px;background:#0000004d;border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column}.call-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px}.call-chat-header button{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:18px}.call-chat-messages{flex:1;overflow-y:auto;padding:12px}.call-overlay-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;background:#0000004d}.call-control-btn{width:48px;height:48px;border-radius:50%;border:none;background:#ffffff26;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;position:relative}.call-control-btn:hover{background:#ffffff40}.call-control-off{background:#ffffff14;color:#ffffff80}.call-control-active{background:var(--color-primary)}.call-control-end{background:var(--color-danger, #ef4444)}.call-control-end:hover{background:#dc2626}.call-participant-count{position:absolute;top:-2px;right:-2px;background:var(--color-primary);font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.messenger-sidebar{width:100vw}.messenger-fullpage{flex-direction:column;margin:8px}.messenger-fullpage-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border);max-height:300px}}.view-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.view-toggle-btn{display:flex;align-items:center;justify-content:center;padding:.35rem .6rem;background:var(--color-bg);border:none;cursor:pointer;color:var(--color-text-secondary);transition:all .15s}.view-toggle-btn:not(:last-child){border-right:1px solid var(--color-border)}.view-toggle-btn:hover{background:var(--color-bg-hover)}.view-toggle-btn.active{background:var(--color-primary);color:#fff}.calendar-month-wrapper{display:flex;flex-direction:column;gap:1rem}.calendar-month-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.25rem 0}.calendar-month-nav{display:flex;gap:.25rem}.calendar-month-title{font-size:1.25rem;font-weight:700;min-width:200px;text-align:center;text-transform:capitalize}.btn-today{padding:.375rem 1rem;font-size:.8125rem;font-weight:500;border:1px solid var(--color-primary);border-radius:6px;background:transparent;color:var(--color-primary);cursor:pointer;transition:all .15s}.btn-today:hover{background:var(--color-primary);color:#fff}.calendar-month-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:var(--color-bg-card, #fff);box-shadow:0 1px 3px #0000000f}.calendar-weekday-header{padding:.75rem;text-align:center;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-bottom:2px solid var(--color-border)}.calendar-day-cell{min-height:120px;padding:.5rem;border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);cursor:pointer;transition:background .15s,box-shadow .15s;display:flex;flex-direction:column}.calendar-day-cell:nth-child(7n){border-right:none}.calendar-day-cell:hover{background:#f0f7ff;box-shadow:inset 0 0 0 1px #3b82f626}[data-theme=dark] .calendar-day-cell:hover{background:#3b82f614;box-shadow:inset 0 0 0 1px #3b82f633}.calendar-day-empty{background:var(--color-bg);cursor:default}.calendar-day-empty:hover,[data-theme=dark] .calendar-day-empty,[data-theme=dark] .calendar-day-empty:hover{background:var(--color-bg);box-shadow:none}.calendar-day-today{background:#3b82f60a;border-color:var(--color-primary)!important}[data-theme=dark] .calendar-day-today{background:#3b82f614}.calendar-day-weekend{background:#f8fafc}[data-theme=dark] .calendar-day-weekend{background:#ffffff05}.calendar-day-number{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.35rem}.calendar-day-today .calendar-day-number{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;background:var(--color-primary);color:#fff;font-weight:700}.calendar-day-events{display:flex;flex-direction:column;gap:3px;flex:1;overflow:hidden}.calendar-event-mini{font-size:.75rem;font-weight:500;padding:2px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;line-height:1.4;transition:opacity .1s,transform .1s}.calendar-event-mini:hover{opacity:.85;transform:translate(1px)}.calendar-event-more{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);padding:2px 6px;cursor:pointer;transition:color .1s}.calendar-event-more:hover{color:var(--color-primary)}.calendar-event-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.calendar-color-palette{display:flex;gap:.75rem;flex-wrap:wrap}.calendar-color-swatch{width:34px;height:34px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px #0000001f}.calendar-color-swatch:hover{transform:scale(1.15)}.calendar-color-swatch.selected{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-bg),0 0 0 4px var(--color-text)}.reminder-chips{display:flex;gap:.35rem;flex-wrap:wrap}.reminder-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;font-size:.75rem;color:var(--color-text-secondary)}.reminder-chip-text{font-weight:500}.calendar-form-row{display:flex;gap:1rem}.calendar-form-row>.form-group{flex:1}.calendar-reminder-row{display:flex;gap:.5rem;align-items:flex-end;margin-bottom:.5rem;flex-wrap:wrap}.calendar-reminder-channels{flex:1}.calendar-channel-toggles{display:flex;gap:.5rem}.channel-toggle{display:inline-flex;align-items:center;gap:.2rem;cursor:pointer;font-size:.85rem;color:var(--color-text-secondary)}.channel-toggle input[type=checkbox]{width:14px;height:14px}.form-section{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section-title{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.form-hint{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;margin-bottom:.35rem}.clickable-text{cursor:pointer;color:var(--color-primary)}.clickable-text:hover{text-decoration:underline}@media(max-width:768px){.calendar-month-header{flex-wrap:wrap;gap:.5rem}.calendar-month-grid{font-size:.8rem}.calendar-day-cell{min-height:80px;padding:.25rem}.calendar-event-mini{font-size:.65rem;padding:1px 3px}.calendar-day-number{font-size:.75rem}.calendar-day-today .calendar-day-number{width:1.5rem;height:1.5rem}.calendar-form-row{flex-direction:column;gap:0}.calendar-reminder-row{flex-direction:column;align-items:stretch}}@media(max-width:480px){.page-content{padding:1rem}.topbar{padding:.5rem 1rem .5rem 3.5rem}.topbar-title{font-size:1rem}.card-header,.card-body{padding:.75rem 1rem}.stats-card{padding:1rem}.filter-bar{flex-wrap:wrap}.call-video-tile-self{width:90px;bottom:60px;right:8px}.messenger-fullpage{margin:4px}.messenger-fullpage-sidebar{max-height:200px}.calendar-day-cell{min-height:60px}.calendar-event-mini{font-size:.6rem}.calendar-month-nav button{padding:.25rem .5rem}}
