@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&family=Inter:wght@300;400;500&display=swap";@import "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-deep:#1a4e8f;--blue-mid:#2d6cc0;--blue-light:#ebf2fc;--blue-xlight:#f4f8fe;--green-deep:#1e6b41;--green-mid:#2e9959;--green-light:#eaf5ee;--green-xlight:#f2faf5;--purple:#7c3aed;--purple-light:#f3effe;--purple-mid:#9333ea;--amber:#e8922a;--amber-light:#fdf3e7;--red:#d94040;--red-light:#fdeaea;--gray-900:#1c2130;--gray-700:#3d4558;--gray-500:#6b7590;--gray-300:#c2c9d8;--gray-100:#f0f2f7;--gray-50:#f8f9fc;--white:#fff;--surface-0:#fff;--surface-1:#f8f9fc;--surface-2:#f0f2f7;--surface-sunken:#ebeef5;--border-subtle:#ebeef5;--border-default:#d5dcea;--border-strong:#c2c9d8;--text-primary:#1c2130;--text-secondary:#3d4558;--text-muted:#6b7590;--sidebar-w:272px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:22px;--radius-pill:999px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-7:32px;--sp-8:40px;--sp-9:48px;--sp-10:64px;--shadow-xs:0 1px 2px #0f1e3c0a;--shadow-sm:0 1px 3px #0f1e3c0f, 0 1px 2px #0f1e3c0a;--shadow-md:0 4px 12px #0f1e3c12, 0 2px 4px #0f1e3c0a;--shadow-lg:0 12px 28px #0f1e3c1a, 0 4px 8px #0f1e3c0d;--shadow-xl:0 24px 48px #0f1e3c1f;--focus-ring:0 0 0 3px #2d6cc038;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--dur-fast:.14s;--dur-base:.2s;--dur-slow:.28s;--transition:.18s ease}body{background:var(--gray-50);color:var(--gray-900);height:100vh;font-family:Inter,sans-serif;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);z-index:10;background:linear-gradient(#1a4e8f 0%,#081b34 100%);border-right:none;flex-direction:column;display:flex;overflow:hidden auto}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}.sidebar-logo{border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;padding:20px 18px 16px;display:flex}.logo-icon{border-radius:var(--radius-md);color:#fff;background:#ffffff1a;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;display:flex}.logo-text .brand{color:#fff;font-family:Montserrat,sans-serif;font-size:14.5px;font-weight:700;line-height:1.1}.logo-text .sub{color:#a1b2d4;letter-spacing:.04em;text-transform:uppercase;font-size:10px}.nav-section{padding:8px 0 2px}.nav-label{letter-spacing:.08em;text-transform:uppercase;color:#8d9ebb;justify-content:space-between;align-items:center;padding:8px 18px 4px;font-size:10px;font-weight:600;display:flex}.nav-label-btn{color:#8d9ebb;cursor:pointer;width:18px;height:18px;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:12px;display:flex}.nav-label-btn:hover{color:#fff;background:#ffffff1a}.nav-item{color:#d1dbef;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition);-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:9px;padding:8px 18px;font-size:13px;display:flex}.nav-item i{text-align:center;color:#8d9ebb;width:16px;transition:color var(--transition);flex-shrink:0;font-size:13px}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item:hover i{color:#fff}.nav-item.active{color:#fff;background:#ffffff1f;border-left-color:#fff;font-weight:600}.nav-item.active i{color:#fff}.nav-item.dm-item:hover{color:#fff;background:#ffffff0f}.nav-item.dm-item:hover i{color:#fff}.nav-item.dm-item.active{color:#fff;background:#ffffff1f;border-left-color:#fff;font-weight:600}.nav-item.dm-item.active i{color:#fff}.sidebar-nav{flex-direction:column;gap:1px;padding:6px 0 8px;display:flex}.nav-section{flex-direction:column;display:flex}.nav-section+.nav-section{margin-top:1px}.nav-section-header{color:#fff;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;border-radius:var(--radius-md);width:calc(100% - 16px);transition:background var(--dur-base) var(--ease-out);background:0 0;border:none;align-items:center;gap:10px;margin:1px 8px;padding:9px 10px;font-family:Inter,sans-serif;font-size:11px;font-weight:700;display:flex}.nav-section-header:hover{color:#fff;background:#ffffff0f}.nav-section-header:focus-visible{outline:none;box-shadow:0 0 0 2px #fff6}.nav-section.has-active-child .nav-section-header,.nav-section.has-active-child .nav-section-header .section-icon{color:#fff}.nav-section-header .section-icon{text-align:center;color:#8d9ebb;width:16px;transition:color var(--dur-base) var(--ease-out);flex-shrink:0;font-size:13px}.nav-section-header:hover .section-icon{color:#fff}.nav-section-header .nav-section-title{color:#fff;flex:1;min-width:0;font-weight:700}.nav-section-header .section-count,.nav-section-header .section-badge{border-radius:var(--radius-pill);letter-spacing:0;text-transform:none;text-align:center;color:#fff;background:#ffffff29;min-width:20px;padding:2px 7px;font-size:10px;font-weight:700;line-height:1.4}.nav-section-header .section-badge.purple{background:var(--purple)}.nav-section-header .section-badge.amber{background:var(--amber)}.nav-section-header .section-badge.red{background:var(--red)}.nav-section-header .section-action{color:#8d9ebb;cursor:pointer;width:22px;height:22px;transition:background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:11px;display:flex}.nav-section-header .section-action:hover{color:#fff;background:#ffffff24}.nav-section-header .chevron{color:#8d9ebb;width:12px;transition:transform var(--dur-slow) var(--ease-in-out), color var(--dur-base) var(--ease-out);flex-shrink:0;font-size:9px}.nav-section.expanded .nav-section-header .chevron{transform:rotate(180deg)}.nav-section-header:hover .chevron{color:#fff}.nav-section-content{transition:grid-template-rows var(--dur-slow) var(--ease-in-out);grid-template-rows:0fr;display:grid}.nav-section.expanded .nav-section-content{grid-template-rows:1fr}.nav-section-content-inner{min-height:0;overflow:hidden}.nav-section.expanded .nav-section-content-inner{padding:2px 0 4px}.nav-empty{color:#7e8aa6;padding:6px 18px;font-size:11px;font-style:italic}.nav-item-action{opacity:0;width:20px;height:20px;transition:opacity var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out);font-size:10px;margin-left:auto!important}.nav-item:hover .nav-item-action,.nav-item:focus-within .nav-item-action{opacity:1}.nav-item.logout,.nav-item.logout i{color:var(--red)}.nav-item.logout:hover{color:var(--red);background:#d9404024}.nav-item.logout:hover i{color:var(--red)}.badge{background:var(--red);color:#fff;text-align:center;border-radius:20px;min-width:18px;margin-left:auto;padding:2px 6px;font-size:10px;font-weight:700;box-shadow:0 1px 3px #0000004d}.badge.green{background:var(--green-mid)}.badge.amber{background:var(--amber)}.badge.purple{background:var(--purple)}.online-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-left:auto;box-shadow:0 0 5px #4ade8080}.dm-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:9px;font-weight:700;display:flex;position:relative}.dm-status{border:2px solid #081b34;border-radius:50%;width:8px;height:8px;position:absolute;bottom:-1px;right:-1px}.dm-status.online{background:#4ade80}.dm-status.away{background:var(--amber)}.dm-status.offline{background:var(--gray-500)}.sidebar-footer{border-top:1px solid #ffffff1a;flex-direction:column;align-items:stretch;gap:10px;margin-top:auto;padding:12px 18px;display:flex}.avatar{background:linear-gradient(135deg,var(--blue-mid),var(--blue-deep));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.avatar.green{background:linear-gradient(135deg,var(--green-mid),var(--green-deep))}.avatar.amber{background:linear-gradient(135deg,var(--amber),#c47320)}.avatar.purple{background:linear-gradient(135deg,var(--purple),#5b21b6)}.user-info .name{color:#fff;font-size:12.5px;font-weight:600}.user-info .role{color:#a1b2d4;font-size:11px}#app{flex-direction:row;width:100vw;display:flex}.main{background:var(--gray-50);flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:var(--white);border-bottom:1px solid var(--gray-100);flex-shrink:0;align-items:center;gap:12px;padding:13px 26px;display:flex}.topbar-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.topbar-icon.channel{background:var(--blue-light);color:var(--blue-mid)}.topbar-icon.dm{background:var(--purple-light);color:var(--purple)}.topbar-icon.tickets{background:var(--blue-light);color:var(--blue-mid)}.topbar-text{flex:1;min-width:0;overflow:hidden}.topbar-title{color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;font-family:Montserrat,sans-serif;font-size:15px;font-weight:700;overflow:hidden}.topbar-sub{color:var(--gray-500);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:12px;overflow:hidden}.topbar-actions{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:6px;padding:8px 15px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;display:inline-flex}.btn-primary{background:var(--blue-mid);color:#fff}.btn-primary:hover{background:var(--blue-deep)}.btn-ghost{color:var(--gray-700);border:1px solid var(--gray-300);background:0 0}.btn-ghost:hover{background:var(--gray-100)}.btn-green{background:var(--green-mid);color:#fff}.btn-green:hover{background:var(--green-deep)}.btn-icon{justify-content:center;width:34px;height:34px;padding:0}.view-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.view{flex-direction:column;flex:1;display:none;overflow:hidden}.view.active{display:flex}.chat-header{background:var(--white);border-bottom:1px solid var(--gray-100);flex-shrink:0;align-items:center;gap:12px;padding:12px 22px;display:flex}.ch-av-group{display:flex}.ch-av-group .avatar{border:2px solid var(--white);width:28px;height:28px;margin-left:-6px;font-size:10px}.ch-av-group .avatar:first-child{margin-left:0}.channel-name{font-size:14px;font-weight:600}.channel-desc{color:var(--gray-500);font-size:12px}.online-pill{background:var(--green-light);color:var(--green-deep);border-radius:20px;align-items:center;gap:5px;margin-left:auto;padding:3px 10px;font-size:11px;font-weight:600;display:flex}.dm-banner{background:var(--purple-light);color:var(--purple);border-bottom:1px solid #e4d4fd;flex-shrink:0;align-items:center;gap:8px;padding:7px 22px;font-size:12px;font-weight:500;display:flex}.messages-area{flex-direction:column;flex:1;gap:3px;padding:18px 22px;display:flex;overflow-y:auto}.messages-area::-webkit-scrollbar{width:5px}.messages-area::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px}.msg-group{align-items:flex-end;gap:9px;margin:7px 0 3px;display:flex}.msg-group.own{flex-direction:row-reverse}.msg-group.own .msg-bubble{background:var(--blue-mid);color:#fff;border-bottom-right-radius:4px;border-bottom-left-radius:var(--radius-lg)}.msg-group.own.dm-msg .msg-bubble{background:var(--purple)}.msg-group.own .msg-meta{text-align:right}.msg-group.own .msg-av{display:none}.msg-content{flex-direction:column;gap:3px;max-width:72%;display:flex}.msg-meta{color:var(--gray-500);align-items:center;gap:8px;padding:0 4px;font-size:11px;display:flex}.msg-meta .sender{color:var(--gray-700);font-weight:600}.msg-bubble{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-lg) 4px;box-shadow:var(--shadow-sm);padding:9px 13px;font-size:13.5px;line-height:1.55}.msg-date-div{text-align:center;color:var(--gray-500);margin:10px 0 6px;font-size:11px;position:relative}.msg-date-div:before{content:"";background:var(--gray-100);z-index:0;height:1px;position:absolute;top:50%;left:0;right:0}.msg-date-div span{background:var(--gray-50);z-index:1;padding:0 10px;position:relative}.dm-start-card{background:var(--purple-light);border-radius:var(--radius-lg);border:1px solid #e4d4fd;align-items:center;gap:14px;margin-bottom:16px;padding:16px 18px;display:flex}.dm-big-av{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:16px;font-weight:700;display:flex}.dm-card-name{color:var(--purple);font-family:Montserrat,sans-serif;font-size:14px;font-weight:700}.dm-card-hint{color:var(--gray-500);margin-top:2px;font-size:12px;line-height:1.5}.dm-lock{color:var(--purple);opacity:.35;margin-left:auto;font-size:22px}.chat-input-area{background:var(--white);border-top:1px solid var(--gray-100);flex-shrink:0;padding:14px 22px}.chat-input-box{background:var(--gray-50);border-radius:var(--radius-xl);transition:border-color var(--transition),background var(--transition);border:1.5px solid #e2e6f0;align-items:flex-end;gap:10px;padding:9px 13px;display:flex}.chat-input-box:focus-within{border-color:var(--blue-mid);background:#fff}.chat-input-box.dm-mode:focus-within{border-color:var(--purple)}.chat-input-box textarea{resize:none;color:var(--gray-900);background:0 0;border:none;outline:none;flex:1;max-height:100px;font-family:Inter,sans-serif;font-size:13.5px;line-height:1.5}.toolbar-btn{border-radius:var(--radius-md);width:30px;height:30px;color:var(--gray-500);cursor:pointer;transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-size:13px;display:flex}.toolbar-btn:hover{background:var(--gray-100);color:var(--blue-mid)}.send-btn{border-radius:var(--radius-md);background:var(--blue-mid);color:#fff;cursor:pointer;width:34px;height:34px;transition:all var(--transition);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;display:flex}.send-btn:hover{background:var(--blue-deep);transform:scale(1.06)}.send-btn.dm{background:var(--purple)}.send-btn.dm:hover{background:#5b21b6}.view-inner{flex:1;padding:22px 26px;overflow-y:auto}.view-inner::-webkit-scrollbar{width:5px}.view-inner::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;display:grid}.stat-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),transform var(--transition);padding:15px 18px}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);margin-bottom:5px;font-size:10.5px;font-weight:600}.stat-val{color:var(--gray-900);font-family:Montserrat,sans-serif;font-size:26px;font-weight:700;line-height:1}.stat-sub{color:var(--gray-500);margin-top:3px;font-size:11px}.stat-icon{float:right;border-radius:var(--radius-md);justify-content:center;align-items:center;width:38px;height:38px;margin-top:-2px;font-size:17px;display:flex}.section-header{align-items:center;gap:10px;margin-bottom:13px;display:flex}.section-title{color:var(--gray-900);font-family:Montserrat,sans-serif;font-size:14px;font-weight:700}.section-count{background:var(--blue-light);color:var(--blue-mid);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700}.tickets-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:13px;display:grid}.ticket-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);transition:all var(--transition);cursor:pointer;border-left:4px solid #0000;padding:16px 18px;animation:.25s slideIn}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.ticket-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.ticket-card.alta{border-left-color:var(--red)}.ticket-card.media{border-left-color:var(--amber)}.ticket-card.baja{border-left-color:var(--green-mid)}.ticket-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:9px;display:flex}.ticket-id{color:var(--gray-500);letter-spacing:.05em;font-size:11px;font-weight:700}.priority-tag{border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:700;display:flex}.priority-tag.alta{background:var(--red-light);color:var(--red)}.priority-tag.media{background:var(--amber-light);color:var(--amber)}.priority-tag.baja{background:var(--green-light);color:var(--green-deep)}.ticket-title{color:var(--gray-900);margin-bottom:5px;font-size:13.5px;font-weight:600;line-height:1.4}.ticket-desc{color:var(--gray-500);margin-bottom:11px;font-size:12px;line-height:1.5}.ticket-meta{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.tag{background:var(--gray-100);color:var(--gray-700);border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:500;display:flex}.tag.blue{background:var(--blue-light);color:var(--blue-deep)}.tag.green{background:var(--green-light);color:var(--green-deep)}.ticket-footer{border-top:1px solid var(--gray-100);align-items:center;gap:8px;margin-top:12px;padding-top:11px;display:flex}.footer-name{color:var(--gray-500);font-size:11px}.ticket-date{color:var(--gray-500);margin-left:auto;font-size:11px}.modal-overlay{z-index:100;background:#0a142873;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:540px;box-shadow:var(--shadow-lg);flex-direction:column;max-height:90vh;animation:.22s modalIn;display:flex}.modal-header{border-bottom:1px solid var(--gray-100);flex-shrink:0;align-items:center;gap:12px;padding:20px 24px 16px;display:flex}.modal-body{flex-direction:column;gap:15px;padding:20px 24px;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--gray-100);flex-shrink:0;justify-content:flex-end;gap:10px;padding:14px 24px 20px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:13px;display:grid}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--gray-700);font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--gray-300);border-radius:var(--radius-md);color:var(--gray-900);background:var(--white);transition:border-color var(--transition);outline:none;padding:9px 11px;font-family:Inter,sans-serif;font-size:13px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue-mid)}.form-group textarea{resize:vertical;min-height:78px}.ticket-detail-history{flex-direction:column;flex:1;gap:8px;min-height:150px;max-height:300px;padding-top:10px;display:flex;overflow-y:auto}.td-history-item{background:var(--gray-50);border-radius:var(--radius-md);border-left:3px solid var(--blue-mid);padding:10px 14px;font-size:12.5px}.td-history-meta{color:var(--gray-500);justify-content:space-between;margin-bottom:4px;font-size:11px;font-weight:600;display:flex}.td-history-status{border-radius:20px;margin-left:6px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-block}.tkt-status-abierto{background:var(--blue-light);color:var(--blue-deep)}.tkt-status-proceso{background:var(--amber-light);color:var(--amber)}.tkt-status-finalizado{background:var(--green-light);color:var(--green-deep)}.ticket-card.finalizado{border-left-color:var(--gray-300);opacity:.75}.ticket-card.finalizado .ticket-title{color:var(--gray-500);text-decoration:line-through}.ticket-card.finalizado:hover{box-shadow:var(--shadow-sm);transform:none}.td-reply-area{border-top:1px solid var(--gray-100);flex-direction:column;gap:10px;padding-top:15px;display:flex}.admin-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.admin-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);overflow:hidden}.admin-card-header{border-bottom:1px solid var(--gray-100);align-items:center;gap:10px;padding:14px 18px;display:flex}.adm-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;display:flex}.adm-icon.blue{background:var(--blue-light);color:var(--blue-mid)}.adm-icon.green{background:var(--green-light);color:var(--green-mid)}.admin-card-body{padding:14px 18px}.adm-title{color:var(--gray-900);font-family:Montserrat,sans-serif;font-size:13px;font-weight:700}.adm-sub{color:var(--gray-500);margin-top:1px;font-size:11px}.user-list,.prov-list{flex-direction:column;gap:8px;max-height:190px;margin-bottom:13px;list-style:none;display:flex;overflow-y:auto}.user-list::-webkit-scrollbar{width:4px}.prov-list::-webkit-scrollbar{width:4px}.user-list::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px}.prov-list::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px}.user-row,.prov-row{border-radius:var(--radius-md);background:var(--gray-50);transition:background var(--transition);align-items:center;gap:9px;padding:7px 9px;display:flex}.user-row:hover,.prov-row:hover{background:var(--blue-xlight)}.u-name{color:var(--gray-900);flex:1;font-size:12.5px;font-weight:500}.role-badge{background:var(--blue-light);color:var(--blue-deep);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.prov-cat{background:var(--green-light);color:var(--green-deep);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.inline-form{flex-direction:column;gap:9px;display:flex}.fr3{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.dm-contact-row{border-radius:var(--radius-md);background:var(--gray-50);cursor:pointer;transition:background var(--transition);align-items:center;gap:10px;padding:9px 12px;display:flex}.dm-contact-row:hover{background:var(--purple-light)}.dm-contact-row .dcr-name{color:var(--gray-900);flex:1;font-size:13px;font-weight:500}.status-pill{border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.status-pill.online{background:var(--green-light);color:var(--green-deep)}.status-pill.away{background:var(--amber-light);color:var(--amber)}.status-pill.offline{background:var(--gray-100);color:var(--gray-500)}.toast{z-index:999;background:var(--gray-900);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;align-items:center;gap:9px;padding:11px 16px;font-size:13px;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:22px;right:22px;transform:translateY(80px)}.toast.show{opacity:1;transform:translateY(0)}.toast i{color:var(--green-mid)}.login-page{z-index:200;background:radial-gradient(ellipse at top left, #2d6cc014, transparent 55%), radial-gradient(ellipse at bottom right, #2e995912, transparent 55%), var(--surface-1);justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;inset:0}.login-card{background:var(--surface-0);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center;width:100%;max-width:400px;animation:loginCardIn var(--dur-slow) var(--ease-out);padding:36px 32px 28px}@keyframes loginCardIn{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:none}}.login-logo{background:linear-gradient(135deg, var(--green-mid), var(--green-deep));border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:76px;height:76px;margin:0 auto 18px;font-size:26px;display:flex;overflow:hidden;box-shadow:0 8px 20px #2e995940}.login-logo.internal{background:linear-gradient(135deg, var(--blue-mid), var(--green-mid));box-shadow:0 8px 20px #2d6cc040}.login-card h2{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:6px;font-family:Montserrat,sans-serif;font-size:22px;font-weight:700}.login-card p{color:var(--text-muted);margin-bottom:26px;font-size:13px;line-height:1.55}.login-card .form-group{text-align:left;margin-bottom:14px}.login-card .form-group label{color:var(--text-secondary);font-size:12px;font-weight:600}.login-card input{border:1.5px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);background:var(--surface-0);transition:border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);outline:none;padding:11px 13px;font-family:Inter,sans-serif;font-size:13.5px}.login-card input:focus{border-color:var(--blue-mid);box-shadow:var(--focus-ring)}.login-card .btn{border-radius:var(--radius-md);letter-spacing:.01em;justify-content:center;width:100%;margin-top:14px;padding:12px;font-size:14px;font-weight:600}.login-card .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #2d6cc040}.login-card .btn-green:hover{transform:translateY(-1px);box-shadow:0 4px 14px #2e995940}.login-lang-corner{z-index:210;position:fixed;top:20px;right:20px}@media (width<=640px){.login-card{max-width:100%;padding:28px 22px 22px}.login-logo{width:64px;height:64px;font-size:22px}.login-card h2{font-size:19px}.login-lang-corner{top:12px;right:12px}}.skel{background:linear-gradient(90deg, var(--surface-2) 0%, var(--surface-sunken) 50%, var(--surface-2) 100%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s ease-in-out infinite skelShimmer;display:block}.skel--text{width:100%;height:12px}.skel--text-sm{width:60%;height:10px}.skel--text-lg{width:80%;height:16px}.skel--card{border-radius:var(--radius-lg);width:100%;height:120px}.skel--ticket{border-radius:var(--radius-lg);width:100%;height:138px}.skel--stat{border-radius:var(--radius-lg);width:100%;height:92px}.skel--circle{border-radius:50%;width:32px;height:32px}.skel--line{height:6px}.skel-stack{flex-direction:column;gap:8px;display:flex}.skel-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:13px;display:grid}.skel-grid-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;display:grid}@keyframes skelShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.skel{opacity:.6;animation:none}}@media (width<=1024px){.skel-grid-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.skel-grid-stats{grid-template-columns:1fr}}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:56px 24px 48px;display:flex}.empty-state__art{width:84px;height:84px;box-shadow:var(--shadow-sm);border-radius:22px;justify-content:center;align-items:center;margin-bottom:16px;font-size:32px;display:flex;position:relative}.empty-state__art:after{content:"";opacity:.18;border:2px dashed;border-radius:26px;position:absolute;inset:-6px}.empty-state__art--blue{background:var(--blue-xlight);color:var(--blue-mid)}.empty-state__art--green{background:var(--green-xlight);color:var(--green-deep)}.empty-state__art--purple{background:var(--purple-light);color:var(--purple)}.empty-state__art--amber{background:var(--amber-light);color:var(--amber)}.empty-state__art--gray{background:var(--surface-2);color:var(--text-muted)}.empty-state__title{color:var(--text-primary);font-family:Montserrat,sans-serif;font-size:15px;font-weight:700}.empty-state__sub{color:var(--text-muted);max-width:360px;margin-top:4px;font-size:13px;line-height:1.55}.empty-state__action{margin-top:18px}button,[role=button]{-webkit-tap-highlight-color:transparent}.btn:focus-visible,.btn-icon:focus-visible,.toolbar-btn:focus-visible,.send-btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.form-group input:focus-visible,.form-group select:focus-visible,.form-group textarea:focus-visible{border-color:var(--blue-mid);box-shadow:var(--focus-ring);outline:none}.btn{letter-spacing:.01em}.btn-primary:hover,.btn-green:hover{box-shadow:var(--shadow-sm)}.btn-ghost:hover{border-color:var(--border-strong)}.stat-card,.ticket-card,.admin-card{border-color:var(--border-subtle)}.mobile-menu-btn{width:38px;height:38px;color:var(--gray-700);background:var(--gray-100);border-radius:var(--radius-md);cursor:pointer;transition:background var(--dur-base) var(--ease-out);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:17px;display:none}.mobile-menu-btn:hover{background:var(--gray-300)}.mobile-menu-btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.mobile-overlay{z-index:190;-webkit-backdrop-filter:blur(3px);background:#0f1e3c80;display:none;position:fixed;inset:0}.sidebar{padding-bottom:env(safe-area-inset-bottom)}.toast{bottom:max(22px, env(safe-area-inset-bottom));right:max(22px, env(safe-area-inset-right))}@media (width<=1024px){.sidebar{z-index:200;box-shadow:var(--shadow-xl);transition:left var(--dur-slow) var(--ease-in-out);position:fixed;top:0;bottom:0;left:-320px;width:280px!important;min-width:280px!important}.sidebar.open{left:0!important}.mobile-menu-btn{display:flex!important}.mobile-overlay.active{display:block}.stats-grid{grid-template-columns:repeat(2,1fr)}.admin-grid{grid-template-columns:1fr}}@media (width<=640px){.topbar{gap:10px;padding:10px 14px}.topbar-title{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:14px;overflow:hidden}.topbar-sub{display:none}.topbar-actions{gap:4px;margin-left:auto}.topbar-actions .btn-primary{display:none}.view-inner{padding:14px}.stats-grid,.form-row,.fr3,.tickets-grid{grid-template-columns:1fr}.btn-icon{width:44px;height:44px;font-size:15px}.mobile-menu-btn{width:44px;height:44px;font-size:18px}.send-btn{width:42px;height:42px}.toolbar-btn{width:38px;height:38px}.nav-item{padding:11px 18px}.nav-section-header{padding:11px 12px}.modal-overlay{align-items:flex-end;padding:0}.modal{width:100%;max-height:92vh;animation:bottomSheetIn var(--dur-slow) var(--ease-out);padding-bottom:env(safe-area-inset-bottom);border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;max-width:100%!important}.modal:before{content:"";background:var(--gray-300);border-radius:var(--radius-pill);width:36px;height:4px;margin:8px auto 0;display:block}@keyframes bottomSheetIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:12px 18px 14px}.modal-body{padding:14px 18px}.modal-footer{padding:12px 18px 16px}.modal-footer .btn{flex:1;justify-content:center}.toast{left:14px;right:14px;bottom:max(14px, env(safe-area-inset-bottom))}.pdf-iframe{display:none!important}}@keyframes modalIn{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:none}}.ticket-closed-info{color:#166534;background:#22c55e14;border-left:3px solid #16a34a;border-radius:4px;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px;padding:6px 8px;font-size:11px;display:flex}.ticket-closed-info i{color:#16a34a}.ticket-closed-banner{color:#166534;background:#22c55e14;border:1px solid #16a34a40;border-left:4px solid #16a34a;border-radius:8px;align-items:flex-start;gap:10px;margin-bottom:10px;padding:10px 12px;font-size:13px;display:flex}.ticket-closed-banner>i{color:#16a34a;margin-top:1px;font-size:18px}.ticket-closed-banner-line{font-size:13px}.ticket-closed-banner-by{color:#166534;opacity:.85;margin-top:2px;font-size:12px}.pwa-banner[data-v-7b8f951a]{left:50%;bottom:calc(16px + env(safe-area-inset-bottom));background:var(--surface-0,#fff);border:1px solid var(--border-subtle,#e2e8f0);border-radius:var(--radius-lg,14px);width:min(560px,100vw - 24px);box-shadow:var(--shadow-lg,0 10px 30px #0f172a2e);z-index:9999;align-items:center;gap:12px;padding:14px 16px;display:flex;position:fixed;transform:translate(-50%)}.pwa-banner-icon[data-v-7b8f951a]{object-fit:cover;border-radius:10px;flex-shrink:0;width:44px;height:44px}.pwa-banner-text[data-v-7b8f951a]{flex:1;min-width:0}.pwa-banner-title[data-v-7b8f951a]{color:var(--text-primary,#0f172a);font-size:14px;font-weight:600}.pwa-banner-sub[data-v-7b8f951a]{color:var(--text-secondary,#475569);margin-top:2px;font-size:12px;line-height:1.35}.pwa-banner-actions[data-v-7b8f951a]{flex-shrink:0;gap:8px;display:flex}.pwa-banner-close[data-v-7b8f951a]{width:26px;height:26px;color:var(--text-muted,#94a3b8);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;top:6px;right:8px}.pwa-banner-close[data-v-7b8f951a]:hover{background:var(--surface-2,#f0f2f7);color:var(--text-primary,#0f172a)}@media (width<=640px){.pwa-banner[data-v-7b8f951a]{flex-wrap:wrap;padding:12px}.pwa-banner-actions[data-v-7b8f951a]{justify-content:flex-end;width:100%;margin-top:4px}.pwa-banner-text[data-v-7b8f951a]{flex-basis:calc(100% - 56px)}}.pwa-modal-overlay[data-v-7b8f951a]{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9999;background:#0f172a8c;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.pwa-modal[data-v-7b8f951a]{background:var(--surface-0,#fff);width:100%;max-width:460px;padding:22px 22px calc(22px + env(safe-area-inset-bottom));border-radius:18px 18px 0 0;animation:.3s ease-out pwa-slide-up-7b8f951a;position:relative;box-shadow:0 -10px 40px #0f172a40}@media (width>=641px){.pwa-modal-overlay[data-v-7b8f951a]{align-items:center;padding:16px}.pwa-modal[data-v-7b8f951a]{border-radius:18px}}.pwa-modal-header[data-v-7b8f951a]{align-items:center;gap:12px;margin-bottom:18px;display:flex}.pwa-modal-icon[data-v-7b8f951a]{object-fit:cover;border-radius:12px;flex-shrink:0;width:48px;height:48px}.pwa-modal-title[data-v-7b8f951a]{color:var(--text-primary,#0f172a);font-size:17px;font-weight:700}.pwa-modal-sub[data-v-7b8f951a]{color:var(--text-secondary,#475569);margin-top:2px;font-size:13px;line-height:1.4}.pwa-modal-close[data-v-7b8f951a]{background:var(--surface-2,#f0f2f7);width:32px;height:32px;color:var(--text-secondary,#475569);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;top:14px;right:14px}.pwa-steps[data-v-7b8f951a]{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.pwa-steps li[data-v-7b8f951a]{align-items:flex-start;gap:12px;display:flex}.pwa-step-num[data-v-7b8f951a]{background:linear-gradient(135deg, var(--blue-mid,#2d6cc0), var(--blue-deep,#1a4e8f));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.pwa-step-body[data-v-7b8f951a]{flex:1;min-width:0}.pwa-step-title[data-v-7b8f951a]{color:var(--text-primary,#0f172a);flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.pwa-step-icon[data-v-7b8f951a]{color:var(--blue-mid,#2d6cc0);font-size:15px}.pwa-step-hint[data-v-7b8f951a]{color:var(--text-muted,#94a3b8);margin-top:2px;font-size:12px;line-height:1.35}.pwa-modal-warning[data-v-7b8f951a]{color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;align-items:flex-start;gap:8px;margin-top:16px;padding:10px 12px;font-size:12px;display:flex}.pwa-modal-footer[data-v-7b8f951a]{margin-top:20px}.pwa-btn[data-v-7b8f951a]{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.pwa-btn[data-v-7b8f951a]:active{transform:scale(.97)}.pwa-btn-primary[data-v-7b8f951a]{background:var(--blue-mid,#2d6cc0);color:#fff}.pwa-btn-primary[data-v-7b8f951a]:hover{background:var(--blue-deep,#1a4e8f)}.pwa-btn-ghost[data-v-7b8f951a]{color:var(--text-secondary,#475569);background:0 0}.pwa-btn-ghost[data-v-7b8f951a]:hover{background:var(--surface-2,#f0f2f7)}.pwa-btn-block[data-v-7b8f951a]{justify-content:center;width:100%;padding:12px;font-size:14px}.pwa-banner-slide-enter-from[data-v-7b8f951a],.pwa-banner-slide-leave-to[data-v-7b8f951a]{opacity:0;transform:translate(-50%)translateY(20px)}.pwa-banner-slide-enter-active[data-v-7b8f951a],.pwa-banner-slide-leave-active[data-v-7b8f951a]{transition:opacity .25s,transform .25s}.pwa-modal-fade-enter-from[data-v-7b8f951a],.pwa-modal-fade-leave-to[data-v-7b8f951a]{opacity:0}.pwa-modal-fade-enter-active[data-v-7b8f951a],.pwa-modal-fade-leave-active[data-v-7b8f951a]{transition:opacity .2s}@keyframes pwa-slide-up-7b8f951a{0%{transform:translateY(100%)}to{transform:translateY(0)}}
