*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-bg:#223843;--sidebar-text:#9aacb4;--sidebar-text-active:#f0f1f4;--sidebar-hover:#ffffff14;--sidebar-accent:#57b36e;--sidebar-width:220px;--bg:#f2f2f2;--bg-card:#fff;--bg-input:#fff;--text-primary:#223843;--text-secondary:#4a6068;--text-muted:#8a9ba2;--border:#dcdcdc;--border-light:#e8e8e8;--accent:#57b36e;--accent-hover:#49a05f;--accent-soft:#57b36e1a;--fg:#223843;--surface-1:#fff;--surface-2:#f5f5f5;--status-open-bg:#dcfce7;--status-open-text:#166534;--status-closed-bg:#fee2e2;--status-closed-text:#991b1b;--green:#57b36e;--amber:#d97706;--red:#dc2626;--radius:8px;--radius-sm:5px;--radius-lg:12px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 1px 3px #0000000a;--font:"DM Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;font-family:var(--font);color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;caret-color:#0000;font-size:14px;line-height:1.5}input,textarea{caret-color:auto}[data-theme=dark]{--bg:#1a1d21;--bg-card:#23272e;--bg-input:#23272e;--text-primary:#e1e4e8;--text-secondary:#9ea7b3;--text-muted:#6b7685;--border:#363b44;--border-light:#2d3139;--accent:#57b36e;--accent-hover:#49a05f;--accent-soft:#57b36e26;--shadow-sm:0 1px 2px #0003;--shadow:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 12px #0000004d, 0 1px 3px #0003;--fg:#e1e4e8;--surface-1:#23272e;--surface-2:#2d3139;--status-open-bg:#57b36e2e;--status-open-text:#6ee7a0;--status-closed-bg:#dc26262e;--status-closed-text:#f87171;--entry-comment-bg:#2a2820;--entry-comment-border:#4a4530;--overlay-bg:#1a1d21d9;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=dark] .status-new{color:#f87171;background:#dc26262e}[data-theme=dark] .status-open{color:#6ee7a0;background:#57b36e2e}[data-theme=dark] .status-progress{color:#60a5fa;background:#2563eb2e}[data-theme=dark] .status-scheduled{color:#a78bfa;background:#8b5cf62e}[data-theme=dark] .status-awaiting{color:#fbbf24;background:#d977062e}[data-theme=dark] .status-hold{color:#9ca3af;background:#6b72802e}[data-theme=dark] .status-billing{color:#fbbf24;background:#eab3082e}[data-theme=dark] .status-resolved{color:#6b7280;background:#6b72801f}[data-theme=dark] .badge-reply{color:#60a5fa;background:#2563eb2e}[data-theme=dark] .badge-comment{color:#fbbf24;background:#d977062e}[data-theme=dark] .reply-notice{color:#60a5fa;background:#2563eb1a}[data-theme=dark] .comment-notice{color:#fbbf24;background:#d977061a}[data-theme=dark] .mention-highlight{color:#60a5fa;background:#2563eb26}[data-theme=dark] .entry-hours-badge{color:#60a5fa;background:#3b82f62e}[data-theme=dark] .result-type-tag.residential{color:#a78bfa;background:#8b5cf62e}[data-theme=dark] .avatar-residential.customer-avatar,[data-theme=dark] .avatar-residential.result-avatar{background:#3b82f6}[data-theme=dark] .ticket-success-banner{color:#6ee7a0;background:#57b36e26;border-color:#57b36e4d}[data-theme=dark] .billable-yes{color:#f87171;background:#dc26262e}[data-theme=dark] .billable-no{color:#6ee7a0;background:#57b36e2e}[data-theme=dark] .delete-confirm-text{color:#f87171}[data-theme=dark] .helpdesk-table tbody tr.row-new{background:#57b36e1a}[data-theme=dark] .helpdesk-table tbody tr.row-new:hover{background:#57b36e29}[data-theme=dark] .notif-item.unread{background:#dc262614}[data-theme=dark] .notif-item.unread:hover{background:#dc262624}[data-theme=dark] .calendar-day-col.today .calendar-day-body{background:#57b36e0f}[data-theme=dark] .calendar-event.has-ticket:hover{background:#57b36e40}[data-theme=dark] .login-btn{color:#1a1d21;background:#e1e4e8}[data-theme=dark] .btn-danger:hover{background:#dc2626}[data-theme=dark] .btn-delete-ticket:hover{background:#dc262626}[data-theme=dark] .btn-print-workorder:hover{background:#3b82f626}body,#root{min-height:100vh}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;flex-direction:column;flex-shrink:0;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:20px 18px 28px;display:flex}.sidebar-logo{background:var(--accent);border-radius:var(--radius);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.sidebar-title{color:var(--sidebar-text-active);letter-spacing:-.3px;font-size:17px;font-weight:600}.sidebar-search{flex-direction:column;gap:6px;padding:0 14px 16px;display:flex;position:relative}.sidebar-search-input-wrap{border-radius:var(--radius);background:#ffffff14;border:1px solid #ffffff1a;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.sidebar-search-input-wrap:focus-within{border-color:var(--accent);background:#ffffff1f}.sidebar-search-icon{color:var(--sidebar-text);opacity:.6;flex-shrink:0;margin-left:10px}.sidebar-search-input-wrap input{width:100%;color:var(--sidebar-text-active);background:0 0;border:none;outline:none;padding:7px 8px;font-size:13px}.sidebar-search-input-wrap input::placeholder{color:var(--sidebar-text);opacity:.5}.search-autocomplete{background:var(--bg-card,#fff);border:1px solid var(--border,#e0e0e0);z-index:100;border-radius:8px;max-height:320px;padding:4px;position:absolute;top:100%;left:14px;right:14px;overflow-y:auto;box-shadow:0 8px 24px #00000026}.search-autocomplete-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .1s;display:flex}.search-autocomplete-item:hover,.search-autocomplete-item.selected{background:var(--surface-2,#f5f5f5)}.search-autocomplete-icon{color:var(--text-secondary,#888);flex-shrink:0;align-items:center;display:flex}.search-autocomplete-text{flex-direction:column;min-width:0;display:flex}.search-autocomplete-label{color:var(--text-primary,#333);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.search-autocomplete-detail{color:var(--text-secondary,#888);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-type-toggle{color:var(--sidebar-text);border-radius:var(--radius-sm);text-align:left;letter-spacing:.3px;background:#ffffff0f;border:1px solid #ffffff14;padding:4px 10px;font-size:11px;font-weight:500;transition:all .15s}.sidebar-type-toggle:hover{color:var(--sidebar-text-active);background:#ffffff1a}.sidebar-nav{flex-direction:column;gap:2px;padding:0 10px;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.8px;color:var(--sidebar-text);opacity:.6;padding:0 8px 6px;font-size:11px;font-weight:600}.sidebar-item{border-radius:var(--radius);color:var(--sidebar-text);text-align:left;align-items:center;gap:10px;padding:9px 10px;font-size:14px;font-weight:450;transition:all .15s;display:flex}.sidebar-item:hover,.sidebar-item.active{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.sidebar-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;left:0}.sidebar-footer{border-top:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding:14px;display:flex}.sidebar-user{align-items:center;gap:10px;min-width:0;display:flex}.sidebar-user-avatar{border-radius:var(--radius);background:var(--sidebar-accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:600;display:flex}.sidebar-user-info{min-width:0}.sidebar-user-name{color:var(--sidebar-text-active);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;display:block;overflow:hidden}.sidebar-footer-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.sidebar-signout{border-radius:var(--radius-sm);color:var(--sidebar-text);flex-shrink:0;padding:6px;transition:all .15s}.sidebar-signout:hover{color:var(--sidebar-text-active);background:#ffffff14}.main-area{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.top-bar{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:14px 28px;display:flex;position:sticky;top:0}.top-bar-left{align-items:center;display:flex}.breadcrumb{color:var(--text-secondary);align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.breadcrumb svg{color:var(--text-muted)}.breadcrumb-link{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:500;transition:color .15s}.breadcrumb-link:hover{color:var(--text-primary)}.search-bar{align-items:center;display:flex}.search-input-wrap{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.search-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-icon{color:var(--text-muted);flex-shrink:0;margin-left:12px}.search-input-wrap input{width:260px;color:var(--text-primary);background:0 0;border:none;outline:none;padding:8px 10px}.search-input-wrap input::placeholder{color:var(--text-muted)}.search-btn{background:var(--accent);color:#fff;border-left:1px solid var(--accent-hover);padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s}.search-btn:hover{background:var(--accent-hover)}.search-type-toggle{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-right:8px;display:flex;overflow:hidden}.type-toggle-btn{color:var(--text-muted);white-space:nowrap;padding:7px 14px;font-size:12px;font-weight:500;transition:all .15s}.type-toggle-btn:hover{color:var(--text-primary)}.type-toggle-btn.active{background:var(--accent);color:#fff}.type-select-group{border:1px solid var(--border);border-radius:var(--radius);display:flex;overflow:hidden}.type-select-btn{color:var(--text-muted);background:var(--bg);flex:1;padding:9px 16px;font-size:13px;font-weight:500;transition:all .15s}.type-select-btn:hover{color:var(--text-primary)}.type-select-btn.active{background:var(--accent);color:#fff}.main-content{flex:1;padding:24px 28px}.welcome-view{justify-content:center;align-items:center;min-height:60vh;display:flex}.welcome-content{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.welcome-content h2{color:var(--text-secondary);margin:0;font-size:20px;font-weight:500}.welcome-content p{color:var(--text-muted);font-size:14px}.search-results{animation:.2s fadeIn}.results-header{align-items:baseline;gap:12px;margin-bottom:16px;display:flex}.results-header h2{margin:0;font-size:18px;font-weight:600}.results-count{color:var(--text-muted);font-size:13px}.results-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:64px 0;display:flex}.results-list{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.result-row{text-align:left;color:var(--text-primary);border-bottom:1px solid var(--border-light);align-items:center;gap:14px;padding:14px 18px;transition:background .12s;display:flex}.result-row:last-child{border-bottom:none}.result-row:hover{background:var(--accent-soft)}.result-avatar{border-radius:var(--radius);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:600;display:flex}.result-info{flex-direction:column;flex:1;gap:2px;display:flex}.result-name{align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.result-type-tag{border-radius:8px;padding:1px 6px;font-size:10px;font-weight:600}.result-type-tag.business{color:var(--accent);background:var(--accent-soft)}.result-type-tag.residential{color:#8b5cf6;background:#8b5cf61a}.result-detail{color:var(--text-muted);font-size:13px}.result-arrow{color:var(--text-muted);flex-shrink:0;transition:transform .15s}.result-row:hover .result-arrow{color:var(--accent);transform:translate(2px)}.customer-view,.service-view{gap:24px;animation:.2s fadeIn;display:flex}.customer-view-left,.service-view-left{flex-direction:column;flex-shrink:0;gap:14px;width:280px;display:flex}.customer-view-right,.service-view-right{flex:1;min-width:0}.back-btn{color:var(--text-muted);align-items:center;gap:6px;padding:4px 0;font-size:13px;font-weight:450;transition:color .15s;display:inline-flex}.back-btn:hover{color:var(--accent)}.customer-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.customer-card-header{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;margin-bottom:14px;padding-bottom:16px;display:flex}.customer-avatar{border-radius:var(--radius);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:600;display:flex}.avatar-residential.customer-avatar,.avatar-residential.result-avatar,.customer-residential .contact-detail-avatar,.customer-residential .contact-search-item-avatar{background:#3b82f6}.customer-card-name{flex:1;margin:0;font-size:15px;font-weight:600;line-height:1.3}.customer-card-name-link{color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;flex:1;margin:0;padding:0;font-size:15px;font-weight:600;line-height:1.3}.customer-card-name-link:hover{text-decoration:underline}.customer-edit-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:4px}.customer-edit-btn:hover{color:var(--accent);background:var(--accent-soft)}.customer-edit-name{border:1px solid var(--border);background:var(--bg);color:var(--fg);border-radius:6px;flex:1;padding:4px 8px;font-size:15px;font-weight:600}.customer-edit-input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--fg);border-radius:6px;padding:4px 8px;font-size:12px}.customer-edit-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.customer-delete-area{margin-left:auto}.customer-delete-confirm{align-items:center;gap:8px;display:flex}.delete-confirm-text{color:var(--status-closed-text,#991b1b);font-size:12px}.customer-card-fields{flex-direction:column;gap:10px;display:flex}.customer-field{flex-direction:column;gap:1px;display:flex}.customer-field-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.customer-field-value{color:var(--text-primary);font-size:13px;font-weight:450}.field-empty{color:var(--text-muted)}.billable-badge,.billable-toggle{cursor:default;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:22px;font-size:12px;font-weight:600;display:inline-flex}.billable-toggle{cursor:pointer}.billable-yes{background:var(--status-closed-bg,#fee2e2);color:var(--status-closed-text,#991b1b)}.billable-no{background:var(--status-open-bg,#dcfce7);color:var(--status-open-text,#166534)}.type-toggle-field{margin-top:4px;margin-bottom:8px}.type-toggle-track{background:var(--bg-secondary,#f1f5f9);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid var(--border,#e2e8f0);border-radius:8px;width:180px;height:32px;display:inline-flex;position:relative;overflow:hidden}.type-toggle-option{z-index:1;color:var(--text-muted,#64748b);flex:1;justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:color .2s;display:flex;position:relative}.type-toggle-option.active{color:#fff}.type-toggle-thumb{border-radius:6px;width:calc(50% - 2px);height:calc(100% - 4px);transition:transform .2s,background .2s;position:absolute;top:2px;left:2px}.type-business .type-toggle-thumb{background:var(--accent,#3b82f6);transform:translate(0)}.type-residential .type-toggle-thumb{background:var(--status-open-text,#166534);transform:translate(100%)}.customer-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:18px;display:flex}.customer-tab{color:var(--text-muted);border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:10px 18px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.customer-tab:hover{color:var(--text-primary)}.customer-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.tab-count{background:var(--border);color:var(--text-secondary);border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.customer-tab.active .tab-count,.tab-count-open{background:var(--accent-soft);color:var(--accent)}.contact-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;gap:8px;margin-bottom:12px;padding:12px;display:flex}.contact-form input{border:1px solid var(--border);background:var(--bg);min-width:140px;color:var(--fg);border-radius:6px;flex:1;padding:6px 10px;font-size:13px}.contact-form-inline{width:100%}.contact-form-actions{align-items:center;gap:6px;display:flex}.contacts-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:1px;display:flex;overflow:hidden}.contact-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.contact-row:last-child{border-bottom:none}.contact-info{flex-direction:column;gap:2px;display:flex}.contact-name{align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.contact-primary-badge{color:var(--accent);background:var(--accent-soft);border-radius:8px;padding:1px 6px;font-size:10px;font-weight:600}.contact-detail{color:var(--text-muted);font-size:12px}.contact-notes-display{color:var(--text-secondary);white-space:pre-wrap;font-size:12px;font-style:italic;line-height:1.4}.contact-notes-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;font-size:13px;font-family:var(--font);color:var(--text-primary);background:var(--bg);resize:vertical;box-sizing:border-box;padding:8px 12px}.contact-notes-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.contact-detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:12px;padding:16px 18px}.contact-detail-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.contact-detail-avatar{border-radius:var(--radius);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:600;display:flex}.contact-detail-avatar.avatar-residential{background:#8b5cf6}.contact-detail-name{color:var(--accent);font-size:14px;font-weight:600}.contact-detail-name.residential{color:#3b82f6}[data-theme=dark] .contact-detail-name.residential{color:#60a5fa}.contact-edit-form{flex-direction:column;gap:8px;display:flex}.contact-edit-form input{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);color:var(--text-primary);background:var(--bg);padding:7px 10px}.contact-edit-form input:focus{border-color:var(--accent);outline:none}.contact-detail-assets{border-top:1px solid var(--border-light);flex-direction:column;gap:4px;margin-top:6px;padding-top:8px;display:flex}.contact-detail-asset{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:6px;padding:5px 8px;font-size:12px;text-decoration:none;transition:background .1s;display:flex}.contact-detail-asset:hover{background:var(--accent-soft);color:var(--accent)}.contact-detail-asset-name{font-weight:500;font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.contact-detail-asset svg:last-child{opacity:0;flex-shrink:0;transition:opacity .1s}.contact-detail-asset:hover svg:last-child{opacity:1}.contact-detail-fields{flex-direction:column;gap:6px;display:flex}.contact-detail-field{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.contact-detail-field svg{color:var(--text-muted);flex-shrink:0}.contact-detail-notes{color:var(--text-secondary);border-top:1px solid var(--border-light);align-items:flex-start;gap:8px;margin-top:4px;padding-top:8px;font-size:13px;font-style:italic;line-height:1.4;display:flex}.contact-detail-notes svg{color:var(--text-muted);flex-shrink:0;margin-top:1px}.contact-license{color:var(--accent);background:var(--accent-soft);white-space:nowrap;border-radius:6px;align-self:flex-start;margin-top:2px;padding:1px 6px;font-size:11px;display:inline-block}.contact-actions{flex-shrink:0;gap:4px;display:flex}.services-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.services-header h2{margin:0;font-size:18px;font-weight:600}.services-empty{text-align:center;color:var(--text-muted);padding:48px 0;font-size:14px}.services-list{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.service-row{text-align:left;color:var(--text-primary);border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:14px 18px;transition:background .12s;display:flex}.service-row:last-child{border-bottom:none}.service-row:hover{background:var(--accent-soft)}.service-icon{border-radius:var(--radius);background:var(--accent-soft);width:36px;height:36px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.service-name{flex:1;font-size:14px;font-weight:450}.service-row:hover .result-arrow{color:var(--accent);transform:translate(2px)}.add-service-form{background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-lg);box-shadow:0 0 0 3px var(--accent-soft);margin-bottom:12px;padding:16px;animation:.15s fadeIn}.add-service-form input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text-primary);outline:none;margin-bottom:10px;padding:10px 12px}.add-service-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.add-service-actions{justify-content:flex-end;gap:8px;display:flex}.service-detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:22px}.service-detail-header{align-items:center;gap:14px;display:flex}.service-detail-icon{border-radius:var(--radius);background:var(--accent-soft);width:44px;height:44px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.service-detail-header h2{margin:0;font-size:17px;font-weight:600}.service-detail-customer{color:var(--text-muted);margin-top:2px;font-size:13px}.ticket-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.ticket-section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.ticket-section-header h3{margin:0;font-size:15px;font-weight:600}.ticket-header-actions{gap:6px;display:flex}.tpl-picker-wrap{justify-content:flex-end;margin-bottom:8px;display:flex;position:relative}.tpl-picker-btn{align-items:center;gap:5px;font-size:12px;display:inline-flex}.tpl-picker-dropdown{z-index:50;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);min-width:260px;max-height:240px;box-shadow:var(--shadow-md);padding:4px;animation:.1s fadeIn;position:absolute;top:100%;right:0;overflow-y:auto}.tpl-picker-item{text-align:left;border-radius:var(--radius-sm);cursor:pointer;width:100%;font-family:var(--font);background:0 0;border:none;flex-direction:column;gap:2px;padding:8px 12px;transition:background .1s;display:flex}.tpl-picker-item:hover{background:var(--accent-soft)}.tpl-picker-item-name{color:var(--text-primary);font-size:13px;font-weight:600}.tpl-picker-item-subject{color:var(--text-muted);font-size:12px}.tpl-form{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.tpl-form-row{gap:8px;display:flex}.tpl-input{border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:var(--font);color:var(--text-primary);background:var(--bg);flex:1;padding:8px 12px}.tpl-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.tpl-form-actions{gap:8px;display:flex}.tpl-list{flex-direction:column;gap:4px;display:flex}.tpl-item{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.tpl-item.editing{border-color:var(--accent);background:var(--accent-soft)}.tpl-item-info{flex-direction:column;gap:1px;min-width:0;display:flex}.tpl-item-name{color:var(--text-primary);font-size:13px;font-weight:600}.tpl-item-subject{color:var(--text-muted);font-size:12px}.tpl-item-actions{flex-shrink:0;gap:6px;display:flex}.ticket-subject-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font);background:var(--bg);color:var(--text-primary);box-sizing:border-box;outline:none;margin-bottom:8px;padding:10px 14px;font-size:14px;font-weight:600;transition:border-color .15s}.ticket-subject-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ticket-subject-input::placeholder{color:var(--text-muted);font-weight:400}.ticket-textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text-primary);resize:vertical;outline:none;min-height:120px;padding:12px 14px;line-height:1.6;transition:border-color .15s}.ticket-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ticket-textarea::placeholder{color:var(--text-muted)}.ticket-footer-row{gap:14px;margin-top:14px;display:flex}.ticket-footer-row input[type=date]{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);outline:none;padding:8px 10px;font-size:13px}.ticket-footer-row input[type=date]:focus,.ticket-footer-row input[type=number]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ticket-footer-row input[type=number]{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);outline:none;width:80px;padding:8px 10px;font-size:13px}.ticket-schedule-toggle{margin:10px 0}.ticket-footer{justify-content:space-between;align-items:flex-end;gap:16px;margin-top:14px;display:flex}.ticket-status-wrap{flex-direction:column;gap:4px;display:flex}.ticket-status-wrap label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.ticket-status-wrap select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239197a6' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:8px 32px 8px 10px}.ticket-status-wrap select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ticket-footer-selects{gap:14px;display:flex}.ticket-submit-wrap{align-items:center;gap:12px;display:flex}.ticket-submitted-msg{color:var(--green);font-size:13px;font-weight:500;animation:.2s fadeIn}.ticket-success-banner{border-radius:var(--radius-lg);color:#3d8a54;background:#57b36e1a;border:1px solid #57b36e4d;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500;animation:.2s fadeIn;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{color:var(--text-secondary);border-radius:var(--radius);border:1px solid var(--border);background:0 0;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:450;transition:all .15s;display:inline-flex}.btn-ghost:hover{background:var(--bg);border-color:var(--text-muted);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12px}.ticket-detail-view{gap:24px;animation:.2s fadeIn;display:flex}.ticket-detail-left{flex-direction:column;flex-shrink:0;gap:14px;width:280px;display:flex}.ticket-detail-right{flex-direction:column;flex:1;gap:16px;min-width:0;display:flex}.ticket-detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px}.ticket-detail-top{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;padding-bottom:16px;display:flex}.ticket-detail-title h2{margin:0 0 4px;font-size:17px;font-weight:600}.ticket-id-label{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px;padding:2px 7px;display:inline-block}.ticket-detail-meta{color:var(--text-muted);font-size:13px}.ticket-detail-hours{color:var(--primary);align-items:center;gap:6px;margin-top:4px;font-size:13px;font-weight:600;display:flex}.ticket-timer{color:var(--text-muted);font-family:monospace;font-size:13px;font-weight:500}.entry-edit-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;margin-left:6px;padding:2px;display:inline-flex}.entry-edit-btn:hover{color:var(--accent);background:var(--accent-soft)}.ticket-edit-form{flex-direction:column;gap:8px;display:flex}.ticket-edit-form input{border:1px solid var(--border);background:var(--bg);color:var(--fg);border-radius:6px;padding:6px 10px;font-size:13px}.ticket-detail-status-wrap{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.ticket-detail-status-wrap label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.ticket-detail-status-wrap select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239197a6' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:7px 30px 7px 10px;font-size:13px}.ticket-detail-selects{flex-shrink:0;gap:14px;display:flex}.ticket-detail-status-wrap select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ticket-detail-body{color:var(--text-primary);white-space:pre-wrap;font-size:14px;line-height:1.7}.btn-save-ticket{align-self:flex-end}.ticket-saved-msg{color:var(--green);align-self:flex-end;padding-bottom:8px;font-size:13px;font-weight:500;animation:.2s fadeIn}.btn-print-workorder{border-radius:var(--radius);width:32px;height:32px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-print-workorder:hover{color:var(--primary);background:#3b82f614}.btn-delete-ticket{border-radius:var(--radius);width:32px;height:32px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-delete-ticket:hover{color:var(--red);background:#dc262614}.btn-danger{background:var(--red);color:#fff;border-radius:var(--radius);border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.btn-danger:hover{background:#b91c1c}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:420px;padding:24px}.modal-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.modal-header h3{margin:0;font-size:16px;font-weight:600}.modal-body-text{color:var(--text-secondary);margin:0 0 20px;font-size:14px;line-height:1.6}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.email-preview-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;width:100%;max-width:600px;max-height:80vh;padding:0;display:flex;overflow:hidden}.email-preview-card .modal-header{border-bottom:1px solid var(--border);margin-bottom:0;padding:16px 20px}.email-preview-meta{border-bottom:1px solid var(--border);background:var(--bg-secondary,#f8fafc);flex-direction:column;gap:6px;padding:12px 20px;display:flex}.email-preview-row{align-items:baseline;gap:10px;font-size:13px;display:flex}.email-preview-label{color:var(--text-muted);text-align:right;min-width:50px;font-weight:600}.email-preview-body{flex:1;min-height:100px;max-height:40vh;padding:20px;font-size:14px;line-height:1.6;overflow-y:auto}.email-preview-card .modal-actions{border-top:1px solid var(--border);padding:14px 20px}.email-preview-card .modal-actions .btn-primary{align-items:center;gap:6px;display:inline-flex}.reviews-view{animation:.2s fadeIn}.reviews-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.reviews-header h2{margin:0;font-size:18px;font-weight:700}.reviews-search{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);align-items:center;gap:8px;min-width:220px;padding:7px 12px;display:flex}.reviews-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.reviews-search svg{color:var(--text-muted);flex-shrink:0}.reviews-search input{font-size:13px;font-family:var(--font);color:var(--text-primary);background:0 0;border:none;outline:none;width:100%}.reviews-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.reviews-table td:last-child{text-align:right;white-space:nowrap}.reviews-table .btn-primary{align-items:center;gap:5px;display:inline-flex}.review-never{color:var(--text-muted);font-size:13px}.review-history{flex-wrap:wrap;gap:4px;display:flex}.review-sent-badge{background:var(--accent-soft);color:var(--accent);cursor:default;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.reviews-success-banner{border-radius:var(--radius);color:var(--accent);background:#57b36e14;border:1px solid #57b36e33;align-items:center;gap:8px;margin-bottom:14px;padding:10px 16px;font-size:13px;font-weight:500;animation:.2s fadeIn;display:flex}.reviews-empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}.review-preview-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;width:100%;max-width:660px;max-height:85vh;padding:0;display:flex;overflow:hidden}.review-preview-card .modal-header{border-bottom:1px solid var(--border);margin-bottom:0;padding:16px 20px}.review-preview-meta{border-bottom:1px solid var(--border);background:var(--bg-secondary,#f8fafc);flex-direction:column;gap:8px;padding:12px 20px;display:flex}.review-preview-email-input{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);color:var(--text-primary);background:var(--bg-card);flex:1;padding:5px 10px}.review-preview-email-input:focus{border-color:var(--accent);outline:none}.review-preview-body{background:#f4f5f7;flex:1;max-height:50vh;padding:20px;overflow-y:auto}[data-theme=dark] .review-preview-body{background:var(--bg)}.review-preview-card .modal-actions{border-top:1px solid var(--border);padding:14px 20px}.review-preview-card .modal-actions .btn-primary{align-items:center;gap:6px;display:inline-flex}.schedule-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.schedule-panel-collapsed{padding:10px 14px}.schedule-panel-header h3{margin:0 0 14px;font-size:15px;font-weight:600}.schedule-loading{text-align:center;color:var(--text-muted);padding:20px;font-size:13px}.schedule-error{color:var(--red);border-radius:var(--radius);background:#dc26260f;border:1px solid #dc262626;margin-bottom:12px;padding:8px 12px;font-size:13px}.schedule-fields{gap:14px;margin-bottom:16px;display:flex}.schedule-field{flex-direction:column;flex:1;gap:4px;display:flex}.schedule-field label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:600}.schedule-field input,.schedule-field select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);outline:none;padding:8px 10px;font-size:13px}.schedule-field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239197a6' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.schedule-field input:focus,.schedule-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.schedule-actions{justify-content:flex-end;gap:10px;display:flex}.login-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md);width:100%;max-width:380px;padding:40px}.login-logo{background:var(--accent);border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex}.login-card h1{color:var(--text-primary);margin:0 0 8px;font-size:22px;font-weight:600}.login-card p{color:var(--text-muted);margin:0 0 28px;font-size:14px}.login-btn{background:var(--text-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px 20px;font-size:14px;font-weight:500;transition:opacity .15s;display:inline-flex}.login-btn:hover{opacity:.9}.ticket-timeline{flex-direction:column;gap:12px;display:flex}.timeline-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:13px}.timeline-entry{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px}.entry-reply{background:var(--bg-card);border:1px solid var(--border)}.entry-comment{background:var(--entry-comment-bg,#fefce8);border:1px solid var(--entry-comment-border,#fde68a)}.timeline-entry-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.timeline-entry-author{align-items:center;gap:8px;display:flex}.entry-type-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.badge-reply{color:#2563eb;background:#2563eb1a}.badge-comment{color:#b45309;background:#d977061f}.timeline-author-name{color:var(--text-primary);font-size:13px;font-weight:500}.timeline-entry-date{color:var(--text-muted);font-size:12px}.timeline-entry-body{color:var(--text-primary);white-space:pre-wrap;font-size:14px;line-height:1.6}.ticket-reply-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.ticket-reply-tabs{border-bottom:1px solid var(--border);display:flex}.reply-tab{color:var(--text-muted);border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:11px 18px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.reply-tab:hover{color:var(--text-primary)}.reply-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.reply-notice{color:#2563eb;border-bottom:1px solid var(--border-light);background:#2563eb0f;padding:8px 16px;font-size:12px}.comment-notice{color:#b45309;border-bottom:1px solid var(--border-light);background:#d977060f;padding:8px 16px;font-size:12px}.ticket-reply-section .ticket-textarea{background:var(--bg-card);border:none;border-radius:0;min-height:100px}.ticket-reply-section .ticket-textarea:focus{box-shadow:none}.ticket-reply-footer{border-top:1px solid var(--border-light);justify-content:space-between;align-items:flex-end;gap:12px;padding:12px 16px;display:flex}.ticket-reply-footer-right{align-items:flex-end;gap:10px;display:flex}.reply-email-fields{border-bottom:1px solid var(--border-light);flex-direction:column;gap:6px;padding:10px 16px;display:flex}.reply-email-row{align-items:center;gap:8px;display:flex}.reply-email-row label{color:var(--text-muted);flex-shrink:0;width:24px;font-size:12px;font-weight:600}.reply-email-row input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-primary);outline:none;flex:1;padding:5px 8px;font-size:13px}.reply-email-row input:focus{border-color:var(--accent)}.entry-hours-input{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.entry-hours-input input{border:1px solid var(--border);background:var(--bg-card);width:64px;color:var(--text);border-radius:6px;padding:6px 8px;font-size:13px}.entry-hours-badge{color:#3b82f6;background:#3b82f61a;border-radius:8px;margin-right:6px;padding:1px 7px;font-size:11px;font-weight:600;display:inline-block}.add-customer-view{max-width:560px;animation:.2s fadeIn}.add-customer-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.add-customer-header{border-bottom:1px solid var(--border-light);color:var(--text-primary);align-items:center;gap:12px;margin-bottom:20px;padding-bottom:18px;display:flex}.add-customer-header h2{margin:0;font-size:17px;font-weight:600}.add-customer-fields{flex-direction:column;gap:14px;display:flex}.form-field{flex-direction:column;gap:4px;display:flex}.form-field label{color:var(--text-secondary);font-size:12px;font-weight:600}.form-field .required{color:var(--red);margin-left:2px}.form-field input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);outline:none;padding:9px 12px;transition:border-color .15s}.form-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-field input::placeholder{color:var(--text-muted)}.add-customer-actions{border-top:1px solid var(--border-light);justify-content:flex-end;align-items:center;gap:10px;margin-top:20px;padding-top:18px;display:flex}.unrecognized-phone{color:var(--text-primary);letter-spacing:.5px;margin:4px 0 2px;font-size:20px;font-weight:600}.unrecognized-desc{color:var(--text-secondary);margin:4px 0 18px;font-size:13px}.unrecognized-choices{gap:12px;display:flex}.unrecognized-choice{background:var(--bg-main);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;flex-direction:column;flex:1;align-items:center;gap:8px;padding:20px 14px;transition:border-color .15s,box-shadow .15s;display:flex}.unrecognized-choice:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-faint,#3b82f61f)}.unrecognized-choice svg{color:var(--accent)}.unrecognized-choice-title{color:var(--text-primary);font-size:14px;font-weight:600}.unrecognized-choice-desc{color:var(--text-secondary);font-size:12px}.existing-customer-results{flex-direction:column;gap:4px;max-height:320px;margin-top:12px;display:flex;overflow-y:auto}.existing-customer-result{background:var(--bg-main);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;align-items:center;gap:10px;width:100%;padding:10px 12px;transition:border-color .15s;display:flex}.existing-customer-result:hover{border-color:var(--accent)}.existing-customer-info{flex-direction:column;flex:1;min-width:0;display:flex}.existing-customer-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.existing-customer-detail{color:var(--text-secondary);font-size:12px}.selected-customer-banner{background:var(--bg-main);border:1px solid var(--accent);border-radius:var(--radius);align-items:center;gap:10px;margin-top:8px;padding:10px 12px;display:flex}.helpdesk-view{animation:.2s fadeIn}.helpdesk-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.helpdesk-header h2{margin:0;font-size:18px;font-weight:600}.helpdesk-filters{align-items:center;gap:12px;display:flex}.helpdesk-filter-select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239197a6' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:7px 30px 7px 10px;font-size:13px}.helpdesk-filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.helpdesk-search-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.helpdesk-search-wrap:focus-within{border-color:var(--accent)}.helpdesk-search-icon{color:var(--text-secondary);flex-shrink:0}.helpdesk-search-input{width:200px;color:var(--text-primary);background:0 0;border:none;outline:none;padding:0;font-size:13px}.helpdesk-search-input::placeholder{color:var(--text-secondary)}.helpdesk-count{color:var(--text-muted);font-size:13px}.helpdesk-layout{gap:20px;display:flex}.helpdesk-sidebar-column{flex-direction:column;flex-shrink:0;align-self:flex-start;gap:12px;width:200px;display:flex;position:sticky;top:80px}.helpdesk-queue-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);padding:8px}.queue-sidebar-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:6px 10px 8px;font-size:11px;font-weight:600}.queue-sidebar-item{width:100%;color:var(--text-secondary);border-radius:var(--radius);text-align:left;justify-content:space-between;align-items:center;padding:8px 10px;font-size:13px;font-weight:450;transition:all .12s;display:flex}.queue-sidebar-item:hover{background:var(--bg);color:var(--text-primary)}.queue-sidebar-item.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.queue-sidebar-info{flex-direction:column;min-width:0;display:flex}.queue-sidebar-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.queue-sidebar-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.queue-sidebar-count{background:var(--border);color:var(--text-secondary);border-radius:10px;flex-shrink:0;padding:1px 7px;font-size:11px;font-weight:600}.queue-sidebar-item.active .queue-sidebar-count{color:var(--accent);background:#57b36e33}.helpdesk-main{flex:1;min-width:0}.helpdesk-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:64px 0;font-size:14px;display:flex}.bulk-action-bar{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius-lg);align-items:center;gap:10px;margin-bottom:10px;padding:8px 14px;font-size:13px;display:flex}.bulk-action-count{color:var(--accent);margin-right:4px;font-weight:600}.bulk-action-select{border:1px solid var(--border);background:var(--bg);color:var(--fg);cursor:pointer;border-radius:6px;padding:4px 8px;font-size:13px}.th-checkbox,.td-checkbox{text-align:center;width:36px;padding:0 8px!important}.clickable-row.row-selected{background:var(--accent-soft)}.helpdesk-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}.helpdesk-table{border-collapse:collapse;width:100%;font-size:13px}.helpdesk-table thead{background:var(--bg);border-bottom:1px solid var(--border)}.helpdesk-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.helpdesk-table td{border-bottom:1px solid var(--border-light);vertical-align:middle;padding:12px 14px}.helpdesk-table tbody tr:last-child td{border-bottom:none}.helpdesk-table tbody tr:hover{background:var(--accent-soft)}.clickable-row{cursor:pointer}.td-queue{color:var(--text-primary);white-space:nowrap;font-weight:500}.td-subject{max-width:300px}.subject-text{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:450;overflow:hidden}.subject-customer{color:var(--text-muted);margin-top:1px;font-size:12px}.td-assigned,.td-poster{white-space:nowrap;color:var(--text-secondary)}.td-duration{white-space:nowrap;font-family:var(--font-mono);color:var(--text-secondary);font-size:12px}.td-created{white-space:nowrap;color:var(--text-muted);font-size:12px}.status-badge{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.status-new{color:#dc2626;background:#dc26261a}.helpdesk-table tbody tr.row-new{border-left:3px solid var(--green);background:#57b36e14}.helpdesk-table tbody tr.row-new:hover{background:#57b36e24}.status-open{color:#3d8a54;background:#57b36e1f}.status-progress{color:#2563eb;background:#2563eb1a}.status-scheduled{color:#7c3aed;background:#8b5cf61a}.status-awaiting{color:#b45309;background:#d977061a}.status-hold{color:#4b5563;background:#6b72801f}.status-billing{color:#a16207;background:#eab3081a}.status-resolved{color:#9ca3af;background:#6b728014}.calendar-view{flex-direction:column;height:calc(100vh - 80px);animation:.2s fadeIn;display:flex}.calendar-toolbar{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.calendar-toolbar-left{align-items:baseline;gap:14px;display:flex}.calendar-toolbar-left h2{margin:0;font-size:18px;font-weight:600}.calendar-week-label{color:var(--text-muted);font-size:14px;font-weight:450}.calendar-toolbar-right{align-items:center;gap:6px;display:flex}.calendar-tech-bar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.calendar-tech-checkboxes{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.calendar-tech-checkbox{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:5px;font-size:13px;font-weight:450;display:flex}.calendar-tech-checkbox input{display:none}.calendar-tech-checkbox-dot{border:2px solid var(--tech-colour);background:0 0;border-radius:3px;flex-shrink:0;width:12px;height:12px;transition:background .15s}.calendar-tech-checkbox input:checked~.calendar-tech-checkbox-dot{background:var(--tech-colour)}.calendar-tech-tabs{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.calendar-tech-tab{border:1px solid;border-radius:20px;align-items:center;gap:6px;padding:3px 8px 3px 10px;font-size:12px;font-weight:600;display:flex}.calendar-tech-tab-close{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:1px;transition:opacity .15s;display:flex}.calendar-tech-tab-close:hover{opacity:1}.calendar-primary-tabs{gap:4px;margin-bottom:8px;display:flex}.calendar-primary-tab{border-radius:var(--radius) var(--radius) 0 0;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:3px solid #0000;align-items:center;gap:8px;padding:10px 16px 10px 24px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.calendar-primary-tab[draggable=true]{cursor:grab}.calendar-primary-tab.dragging{opacity:.4;transform:scale(.9)}.calendar-primary-tab:hover{color:var(--tab-text);background:var(--tab-bg)}.calendar-primary-tab.active{background:var(--tab-bg);color:var(--tab-text);border-bottom-color:var(--tab-colour);font-weight:600}.calendar-tab-close{color:inherit;opacity:.5;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:2px;transition:opacity .15s,background .15s;display:flex}.calendar-tab-close:hover{opacity:1;background:#00000014}[data-theme=dark] .calendar-tab-close:hover{background:#ffffff1a}.calendar-staff-select{border:1px solid var(--border);background:var(--bg);color:var(--fg);cursor:pointer;border-radius:6px;margin-left:12px;padding:4px 8px;font-size:13px}.calendar-grid-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-sm);border-top:none;flex:1;min-height:0;position:relative;overflow-y:auto}.calendar-loading{background:var(--overlay-bg,#fffc);z-index:5;color:var(--text-muted);justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;inset:0}.calendar-grid{display:flex}.calendar-gutter{border-right:1px solid var(--border-light);flex-shrink:0;width:64px}.calendar-header-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-bottom:none;display:flex}.calendar-header-row .calendar-gutter-header{border-right:1px solid var(--border-light);flex-shrink:0;width:64px}.calendar-header-row .calendar-day-header{flex:1}.calendar-gutter-header{height:40px}.calendar-gutter-label{height:64px;color:var(--text-muted);justify-content:flex-end;align-items:flex-start;padding:0 8px;font-size:11px;display:flex}.calendar-gutter-label:first-child{padding-top:2px}.calendar-gutter-label:not(:first-child){transform:translateY(-7px)}.calendar-day-col{border-right:1px solid var(--border-light);flex:1;min-width:0}.calendar-day-col:last-child{border-right:none}.calendar-day-header{height:40px;color:var(--text-secondary);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.3px;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.calendar-day-header.today{color:var(--accent)}.calendar-day-body{position:relative}.calendar-hour-row{border-bottom:1px solid var(--border-light);cursor:pointer;height:64px}.calendar-hour-row:hover{background:var(--accent-soft)}.calendar-hour-row:last-child{border-bottom:none}.calendar-event{border-radius:var(--radius-sm);cursor:default;z-index:2;padding:2px 6px;font-size:11px;line-height:1.4;position:absolute;overflow:hidden}.calendar-event:hover{z-index:20;overflow:visible}.calendar-event.has-ticket{cursor:pointer}.calendar-event.has-ticket:hover{opacity:.85}.calendar-event-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);color:var(--text-primary);white-space:nowrap;z-index:30;pointer-events:none;margin-bottom:4px;padding:8px 12px;font-size:12px;line-height:1.5;display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.calendar-event:hover .calendar-event-tooltip{display:block}.calendar-event-tooltip strong{margin-bottom:2px;font-size:13px;display:block}.calendar-event-time{color:inherit;white-space:nowrap;font-weight:600;display:block}.calendar-event-subject{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.calendar-event.compact{align-items:center;gap:6px;padding:1px 6px;display:flex}.calendar-event.compact .calendar-event-time,.calendar-event.compact .calendar-event-subject{flex-shrink:0;display:inline}.calendar-event.compact .calendar-event-subject{flex-shrink:1;min-width:0}.calendar-day-col.today .calendar-day-body{background:#57b36e08}.cipp-view{animation:.2s fadeIn}.cipp-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.cipp-header h2{margin:0;font-size:18px;font-weight:700}.cipp-header-actions{gap:8px;display:flex}.cipp-result{border-radius:var(--radius-lg);background:var(--accent-soft);border:1px solid var(--accent);margin-bottom:14px;padding:10px 14px;font-size:13px}.cipp-result.has-errors{border-color:var(--red);background:#ef444414}.cipp-errors{color:var(--red);margin-top:6px;font-size:12px}.cipp-error{padding:2px 0}.cipp-empty{text-align:center;color:var(--text-muted);padding:60px 20px}.cipp-filters{gap:6px;margin-bottom:12px;display:flex}.cipp-filters .active{background:var(--accent-soft);color:var(--accent)}.cipp-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}.cipp-skip-badge{background:var(--border);color:var(--text-muted);border-radius:8px;padding:2px 8px;font-size:11px}.cipp-mapped-badge{color:var(--accent);font-size:12px;font-weight:600}.cipp-suggested{color:var(--text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.cipp-assign-row{align-items:center;gap:6px;display:flex}.cipp-assign-select{border:1px solid var(--border);background:var(--bg);color:var(--fg);border-radius:6px;max-width:200px;padding:4px 8px;font-size:12px}.cipp-action-btns{flex-wrap:wrap;gap:4px;display:flex}.row-skipped{opacity:.5}.td-actions{white-space:nowrap;min-width:300px}.quick-ticket-view{max-width:700px;animation:.2s fadeIn}.quick-ticket-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.quick-ticket-header h2{margin:0;font-size:18px;font-weight:700}.quick-ticket-header-right{align-items:center;gap:12px;display:flex}.quick-ticket-customer{margin-bottom:14px}.quick-ticket-search{position:relative}.quick-ticket-search input{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);width:100%;color:var(--fg);padding:10px 14px;font-size:14px}.quick-ticket-search input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft);outline:none}.quick-ticket-results{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md,0 4px 12px #00000026);z-index:10;max-height:250px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.quick-ticket-result{border:none;border-bottom:1px solid var(--border-light);cursor:pointer;width:100%;color:var(--fg);text-align:left;background:0 0;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.quick-ticket-result:last-child{border-bottom:none}.quick-ticket-result:hover{background:var(--accent-soft)}.quick-ticket-result-name{font-size:13px;font-weight:600}.quick-ticket-result-contact{color:var(--text-muted);font-size:12px}.quick-ticket-selected{background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-lg);align-items:center;gap:12px;padding:10px 14px;display:flex}.quick-ticket-customer-name{flex:1;font-size:15px;font-weight:700}.quick-ticket-schedule-section{border-top:1px solid var(--border-light);margin-top:10px;padding-top:10px}.quick-ticket-schedule-section h4{color:var(--text-secondary);margin:0 0 8px;font-size:13px;font-weight:600}.mention-highlight{color:#2563eb;background:#2563eb14;border-radius:3px;padding:1px 4px;font-weight:600}.mention-wrap{position:relative}.mention-highlight-overlay{font-family:inherit;font-size:inherit;white-space:pre-wrap;word-wrap:break-word;pointer-events:none;color:var(--text-primary);-webkit-user-select:none;user-select:none;border:none;padding:12px 14px;line-height:1.6;position:absolute;inset:0;overflow:hidden}.mention-highlight-overlay,.mention-highlight-overlay *{caret-color:#0000!important}.mention-textarea{color:#0000;caret-color:var(--text-primary);background:0 0}.mention-textarea::placeholder{color:var(--text-muted)}.mention-inline-mark{color:#2563eb;background:0 0;font-weight:600}[data-theme=dark] .mention-inline-mark{color:#60a5fa}.mention-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:20;max-height:180px;position:absolute;overflow-y:auto}.mention-item{width:100%;color:var(--text-primary);text-align:left;border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;transition:background .1s;display:flex}.mention-item:last-child{border-bottom:none}.mention-item:hover,.mention-item.active{background:var(--accent-soft)}.mention-name{font-weight:500}.mention-email{color:var(--text-muted);font-size:11px}.mention-dropdown-below{margin-top:4px;margin-bottom:0;top:100%;bottom:auto}.queue-sidebar-item.drag-over{background:var(--accent-soft);outline:2px dashed var(--accent);outline-offset:-2px}.clickable-row[draggable=true]{cursor:grab}.clickable-row[draggable=true]:active{cursor:grabbing;opacity:.6}.top-bar-right{align-items:center;display:flex}.notif-wrap{position:relative}.notif-bell{border-radius:var(--radius);color:var(--text-secondary);padding:6px;transition:all .15s;position:relative}.notif-bell:hover{background:var(--bg);color:var(--text-primary)}.notif-badge{background:var(--red);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:0;right:0}.notif-backdrop{z-index:99;position:fixed;inset:0}.notif-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:360px;box-shadow:var(--shadow-md);z-index:100;margin-top:8px;animation:.15s fadeIn;position:absolute;top:100%;right:0;overflow:hidden}.notif-dropdown-header{color:var(--text-primary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:14px;font-weight:600}.notif-empty{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:13px}.notif-list{max-height:360px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border-light);cursor:pointer;align-items:flex-start;gap:8px;padding:12px 16px;transition:background .1s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--accent-soft)}.notif-item.unread{background:#dc26260a}.notif-item.unread:hover{background:#dc262614}.notif-item-content{flex:1;min-width:0}.notif-item-title{color:var(--text-primary);align-items:center;gap:6px;font-size:13px;display:flex}.notif-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:8px;height:8px}.notif-item-detail{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:3px;font-size:12px;overflow:hidden}.notif-item-time{color:var(--text-muted);opacity:.7;margin-top:3px;font-size:11px}.notif-remove{border-radius:var(--radius-sm);color:var(--text-muted);flex-shrink:0;margin-top:2px;padding:4px;transition:all .15s}.notif-remove:hover{color:var(--red);background:#dc262614}.workorder-view{max-width:640px;animation:.2s fadeIn}.workorder-view h2{margin:0 0 18px;font-size:18px;font-weight:600}.workorder-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:22px}.workorder-card h3{margin:0 0 14px;font-size:15px;font-weight:600}.workorder-search-row{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.workorder-type-toggle{border:1px solid var(--border);border-radius:var(--radius);width:fit-content;display:flex;overflow:hidden}.workorder-search-input{gap:8px;display:flex}.workorder-search-input input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-primary);outline:none;flex:1;padding:9px 12px;font-size:13px}.workorder-search-input input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.workorder-results{border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;margin-bottom:12px;display:flex;overflow:hidden}.workorder-result-row{text-align:left;border-bottom:1px solid var(--border-light);color:var(--text-primary);justify-content:space-between;align-items:center;padding:10px 14px;transition:background .1s;display:flex}.workorder-result-row:last-child{border-bottom:none}.workorder-result-row:hover{background:var(--accent-soft)}.workorder-result-name{font-size:14px;font-weight:500}.workorder-result-detail{color:var(--text-muted);margin-top:1px;font-size:12px}.workorder-no-results{text-align:center;color:var(--text-muted);margin-bottom:12px;padding:20px;font-size:13px}.workorder-new-btn{justify-content:center;width:100%}.workorder-form-fields{flex-direction:column;gap:12px;margin-bottom:18px;display:flex}.workorder-form-row{gap:12px;display:flex}.workorder-form-row .form-field{flex:1}.workorder-customer-banner{background:var(--accent-soft);border-radius:var(--radius);color:var(--text-primary);margin-bottom:16px;padding:10px 14px;font-size:14px}.workorder-device-select{border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;display:flex;overflow:hidden}.workorder-checkbox-label{color:var(--text-primary);cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.workorder-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.workorder-price-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);align-items:center;width:140px;display:flex;overflow:hidden}.workorder-price-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.workorder-price-prefix{color:var(--text-muted);padding:8px 0 8px 10px;font-size:14px;font-weight:500}.workorder-price-input input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;padding:8px 10px 8px 4px;font-size:14px}.workorder-agreement{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px 18px}.workorder-agreement h4{color:var(--text-primary);margin:0 0 6px;font-size:13px;font-weight:600}.workorder-agreement h4:not(:first-child){margin-top:14px}.workorder-agreement p{color:var(--text-secondary);margin:0 0 8px;font-size:12px;line-height:1.6}.workorder-agreement p:last-child{margin-bottom:0}.workorder-actions{border-top:1px solid var(--border-light);justify-content:flex-end;gap:10px;padding-top:14px;display:flex}.workorder-colour-select{flex-wrap:wrap;gap:6px;display:flex}.colour-tag-btn{border:2px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.colour-tag-btn:hover{border-color:var(--tag-colour)}.colour-tag-btn.active{border-color:var(--tag-colour);background:var(--tag-colour);color:#fff}.colour-tag-btn.in-use{opacity:.4}.colour-tag-btn.in-use.active{opacity:1}.colour-tag-dot{background:var(--tag-colour);border-radius:50%;flex-shrink:0;width:10px;height:10px}.colour-tag-btn.active .colour-tag-dot{background:#fff9}.tag-colour-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-right:6px;display:inline-block}.settings-view{max-width:640px;animation:.2s fadeIn}.settings-view h2{margin:0 0 18px;font-size:18px;font-weight:600}.settings-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px}.settings-card-header{border-bottom:1px solid var(--border-light);margin-bottom:18px;padding-bottom:16px}.settings-user-info{align-items:center;gap:12px;display:flex}.settings-user-name{color:var(--text-primary);font-size:15px;font-weight:600}.settings-user-email{color:var(--text-muted);font-size:13px}.settings-section h3{margin:0 0 6px;font-size:15px;font-weight:600}.settings-hint{color:var(--text-muted);margin:0 0 12px;font-size:12px}.settings-signature-input{font-family:var(--font-mono);font-size:12px}.settings-signature-preview{border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;overflow:hidden}.settings-preview-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border-light);padding:6px 12px;font-size:11px;font-weight:600}.settings-preview-content{padding:12px;font-size:14px;line-height:1.5}.settings-actions{border-top:1px solid var(--border-light);justify-content:flex-end;margin-top:16px;padding-top:14px;display:flex}.theme-toggle-row{justify-content:space-between;align-items:center;padding:4px 0;display:flex}.theme-toggle-label{color:var(--text-primary);font-size:14px;font-weight:450}.theme-toggle-switch{background:var(--border);cursor:pointer;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .2s;position:relative}.theme-toggle-switch.active{background:var(--accent)}.theme-toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.theme-toggle-switch.active .theme-toggle-knob{transform:translate(20px)}.admin-view{animation:.2s fadeIn}.admin-tabs{border-bottom:1px solid var(--border,#e5e5e5);gap:2px;margin-bottom:20px;display:flex}.admin-tab{color:var(--text-secondary,#888);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s;display:flex}.admin-tab:hover{color:var(--text-primary,#333)}.admin-tab.active{color:var(--primary,#2563eb);border-bottom-color:var(--primary,#2563eb)}.admin-tab svg{flex-shrink:0}.admin-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px}.admin-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.admin-card-header h3{margin:0;font-size:15px;font-weight:600}.admin-form{background:var(--bg);border:1px solid var(--accent);border-radius:var(--radius);box-shadow:0 0 0 3px var(--accent-soft);margin-bottom:14px;padding:16px}.admin-form-fields{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.admin-form-row{gap:12px;display:flex}.admin-form-row .form-field{flex:1}.admin-form-actions{justify-content:flex-end;gap:8px;display:flex}.admin-catalog-list{border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;display:flex;overflow:hidden}.admin-catalog-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.admin-catalog-row:last-child{border-bottom:none}.admin-catalog-row.editing{background:var(--accent-soft)}.admin-catalog-info{flex-direction:column;gap:2px;display:flex}.admin-catalog-name{color:var(--text-primary);font-size:14px;font-weight:500}.admin-catalog-costs{color:var(--text-muted);font-size:12px}.admin-catalog-actions{flex-shrink:0;gap:6px;display:flex}.admin-billing-row{align-items:center;gap:12px;display:flex}.service-row-info{cursor:default}.service-row-details{flex-direction:column;flex:1;gap:1px;display:flex}.service-billing{color:var(--text-muted);font-size:12px}.service-covered-badge{color:var(--accent);background:var(--accent-soft);border-radius:8px;margin-left:8px;padding:1px 6px;font-size:10px;font-weight:600}.service-group{border-bottom:1px solid var(--border-light)}.service-group:last-child{border-bottom:none}.service-child{background:var(--bg);border-top:1px solid var(--border-light);padding-left:36px!important}.service-child .service-icon svg{opacity:.5;width:14px;height:14px}.service-edit-form{flex-direction:column;gap:8px;width:100%;display:flex}.service-edit-fields{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.options-wrap{position:relative}.options-backdrop{z-index:9;position:fixed;inset:0}.options-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:10;min-width:170px;margin-top:4px;animation:.1s fadeIn;position:absolute;top:100%;right:0;overflow:hidden}.options-item{width:100%;color:var(--text-primary);text-align:left;border-bottom:1px solid var(--border-light);align-items:center;gap:8px;padding:9px 14px;font-size:13px;transition:background .1s;display:flex}.options-item:last-child{border-bottom:none}.options-item:hover{background:var(--accent-soft)}.options-item-danger{color:var(--red)}.options-item-danger:hover{background:#dc26260f}.email-unmatched-banner{border-radius:var(--radius-lg);background:#d9770614;border:1px solid #d9770640;margin-bottom:16px;padding:14px 18px;animation:.2s fadeIn}.email-unmatched-banner-text{color:var(--amber);align-items:center;gap:8px;margin-bottom:10px;font-size:13px;font-weight:500;display:flex}.email-unmatched-actions{align-items:flex-start;gap:8px;display:flex}.email-unmatched-search{flex:1;position:relative}.email-unmatched-search input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);width:100%;color:var(--text-primary);outline:none;padding:7px 12px;font-size:13px}.email-unmatched-search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.email-unmatched-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:20;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.email-unmatched-result{cursor:pointer;text-align:left;width:100%;color:var(--text-primary);border:none;border-bottom:1px solid var(--border-light);background:0 0;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.email-unmatched-result:last-child{border-bottom:none}.email-unmatched-result:hover{background:var(--accent-soft)}.email-unmatched-result-name{font-weight:500}.email-unmatched-result-detail{color:var(--text-muted);font-size:12px}.email-html-body{color:var(--text-primary);word-break:break-word;cursor:default;font-size:14px;line-height:1.6;overflow:hidden}.email-html-body,.email-html-body *{-webkit-user-select:text;user-select:text;caret-color:#0000!important;-webkit-user-modify:read-only!important}.email-html-body img{max-width:100%;height:auto}.email-html-body table{border-collapse:collapse;max-width:100%}.email-html-body pre,.email-html-body code{white-space:pre-wrap;word-break:break-word}.email-via-badge{color:#2563eb;background:#2563eb1a;border-radius:8px;margin-left:4px;padding:1px 6px;font-size:10px;font-weight:600}[data-theme=dark] .email-via-badge{color:#60a5fa;background:#2563eb2e}[data-theme=dark] .email-unmatched-banner{background:#d977061f;border-color:#d977064d}.impersonation-banner{color:#7c3aed;background:#8b5cf61a;border-bottom:1px solid #8b5cf640;justify-content:center;align-items:center;gap:12px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.impersonation-banner button{color:#7c3aed;border-color:#8b5cf64d}.impersonation-banner button:hover{background:#8b5cf626}[data-theme=dark] .impersonation-banner{color:#a78bfa;background:#8b5cf626;border-color:#8b5cf64d}[data-theme=dark] .impersonation-banner button{color:#a78bfa}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.contact-assets{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.contact-asset-badge{background:var(--surface-2,#f0f0f0);color:var(--text-secondary,#666);border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;line-height:1.4;display:inline-flex}.contact-devices{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.contact-device-chip{background:var(--surface-2,#f5f5f5);border:1px solid var(--border,#e5e5e5);color:inherit;cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}.contact-device-chip:hover{border-color:var(--primary,#2563eb);box-shadow:0 0 0 1px var(--primary,#2563eb)}.contact-device-icon{color:var(--text-secondary,#888);flex-shrink:0}.contact-device-chip:hover .contact-device-icon{color:var(--primary,#2563eb)}.contact-device-info{flex-direction:column;min-width:0;display:flex}.contact-device-name{color:var(--text-primary,#333);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.contact-device-specs{color:var(--text-secondary,#888);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.contact-device-arrow{color:var(--text-secondary,#ccc);flex-shrink:0;margin-left:2px}.contact-device-chip:hover .contact-device-arrow{color:var(--primary,#2563eb)}.contact-device-chip.selected{border-color:var(--green,#22c55e);background:#22c55e0d}.contact-device-main{cursor:pointer;text-align:left;min-width:0;color:inherit;background:0 0;border:none;flex:1;align-items:center;gap:8px;padding:0;display:flex}.device-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.device-status-dot.online{background:#22c55e;box-shadow:0 0 4px #22c55e66}.device-status-dot.offline{background:#dc2626;box-shadow:0 0 4px #dc26264d}.contact-device-ninja-link{color:var(--text-secondary,#aaa);border-left:1px solid var(--border,#e5e5e5);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-left:4px;padding:4px 4px 4px 8px;display:flex}.contact-device-ninja-link:hover{color:var(--primary,#2563eb);background:#2563eb0f}.asset-badge-remove{color:var(--text-secondary,#999);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.asset-badge-remove:hover{color:var(--red,#dc2626)}.asset-picker{flex-direction:column;gap:6px;display:flex}.asset-search-picker{position:relative}.asset-search-input-wrap{border:1px solid var(--border,#e0e0e0);background:var(--bg-card,#fff);border-radius:6px;align-items:center;gap:6px;padding:5px 10px;display:flex}.asset-search-input-wrap svg{color:var(--text-secondary,#aaa);flex-shrink:0}.asset-search-input-wrap input{width:100%;color:var(--text-primary,#333);background:0 0;border:none;outline:none;font-size:13px}.asset-search-input-wrap input::placeholder{color:var(--text-secondary,#aaa)}.asset-search-dropdown{background:var(--bg-card,#fff);border:1px solid var(--border,#e0e0e0);z-index:20;border-top:none;border-radius:0 0 6px 6px;max-height:220px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.asset-search-option{cursor:pointer;text-align:left;width:100%;color:var(--text-secondary,#888);background:0 0;border:none;align-items:center;gap:8px;padding:7px 10px;display:flex}.asset-search-option:hover{background:var(--surface-2,#f5f5f5)}.asset-search-option-info{flex-direction:column;min-width:0;display:flex}.asset-search-option-name{color:var(--text-primary,#333);font-size:13px;font-weight:500}.asset-search-option-specs{color:var(--text-secondary,#888);font-size:11px}.asset-badges{flex-wrap:wrap;gap:4px;display:flex}.ticket-detail-assets{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.ticket-assets-label{color:var(--text-secondary,#888);font-size:12px;font-weight:500}.ticket-detail-add-asset{margin-top:4px}.ticket-detail-add-asset select{border:1px solid var(--border,#e0e0e0);background:var(--surface-1,#fff);color:var(--text-primary,#333);border-radius:4px;padding:3px 8px;font-size:12px}.contact-detail-section{background:var(--bg-card,#fff);border:1px solid var(--border,#e5e5e5);border-radius:8px;margin-bottom:16px;padding:14px}.contact-detail-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.contact-detail-info{align-items:center;gap:12px;min-width:0;display:flex}.contact-detail-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:600;display:flex}.contact-detail-text{flex-direction:column;min-width:0;display:flex}.contact-detail-name{color:var(--text-primary,#333);align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.contact-detail-meta{color:var(--text-secondary,#888);font-size:12px}.contact-detail-assets{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.contact-detail-tickets{margin-top:10px}.contact-tickets-toggle{color:var(--text-secondary,#666);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:4px 0;font-size:13px;font-weight:500;display:flex}.contact-tickets-toggle:hover{color:var(--primary,#2563eb)}.contact-tickets-list{flex-direction:column;gap:2px;margin-top:6px;display:flex}.contact-ticket-row{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:6px 8px;display:flex}.contact-ticket-row:hover{background:var(--surface-2,#f5f5f5)}.contact-ticket-id{color:var(--text-secondary,#888);flex-shrink:0;width:70px;font-size:12px;font-weight:600}.contact-ticket-subject{color:var(--text-primary,#333);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.status-badge-sm{padding:1px 6px;font-size:10px}.contact-search-section{margin-bottom:16px}.contact-search-wrap{background:var(--bg-card,#fff);border:1px solid var(--border,#e5e5e5);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.contact-search-icon{color:var(--text-secondary,#888);flex-shrink:0}.contact-search-input{width:100%;color:var(--text-primary,#333);background:0 0;border:none;outline:none;font-size:13px}.contact-search-input::placeholder{color:var(--text-secondary,#aaa)}.contact-search-results{background:var(--bg-card,#fff);border:1px solid var(--border,#e5e5e5);border-top:none;border-radius:0 0 8px 8px;max-height:280px;overflow-y:auto}.contact-search-item{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 12px;display:flex}.contact-search-item:hover{background:var(--surface-2,#f5f5f5)}.contact-search-item-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.contact-search-item-info{flex-direction:column;min-width:0;display:flex}.contact-search-item-name{color:var(--text-primary,#333);align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.contact-search-item-detail{color:var(--text-secondary,#888);font-size:11px}.contact-tab-search{background:var(--bg-card,#fff);border:1px solid var(--border,#e5e5e5);border-radius:8px;flex:1;align-items:center;gap:8px;padding:8px 12px;display:flex}.contact-tab-search input{width:100%;color:var(--text-primary,#333);background:0 0;border:none;outline:none;font-size:13px}.contact-tab-search input::placeholder{color:var(--text-secondary,#aaa)}.contact-tab-search svg{color:var(--text-secondary,#888);flex-shrink:0}.passwords-list{flex-direction:column;gap:8px;display:flex}.password-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e5e5e5);border-radius:8px;transition:border-color .15s;overflow:hidden}.password-card.revealed{border-color:var(--primary,#2563eb)}.password-header{cursor:pointer;justify-content:space-between;align-items:center;padding:10px 14px;transition:background .1s;display:flex}.password-header:hover{background:var(--surface-2,#f9f9f9)}.password-info{align-items:center;gap:10px;min-width:0;display:flex}.password-icon{color:var(--text-secondary,#888);flex-shrink:0}.password-text{flex-direction:column;min-width:0;display:flex}.password-name{color:var(--text-primary,#333);font-size:13px;font-weight:500}.password-username{color:var(--text-secondary,#888);font-size:12px}.password-actions-row{flex-shrink:0;align-items:center;gap:8px;display:flex}.password-revealed{border-top:1px solid var(--border,#e5e5e5);border-top:1px solid var(--border,#eee);flex-direction:column;gap:8px;margin:0 14px 12px;padding:12px 14px;display:flex}.password-field{flex-direction:column;gap:2px;display:flex}.password-field-label{color:var(--text-secondary,#888);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.password-field-value-row{align-items:center;gap:8px;display:flex}.password-field-value{color:var(--text-primary,#333);background:var(--surface-2,#f5f5f5);word-break:break-all;border-radius:4px;flex:1;padding:4px 8px;font-family:SF Mono,Consolas,Monaco,monospace;font-size:13px}.password-copy{cursor:pointer;color:var(--text-secondary,#888);background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:4px;display:flex}.password-copy:hover{background:var(--surface-2,#f0f0f0);color:var(--primary,#2563eb)}.integration-sub-tabs{gap:4px;margin-bottom:16px;display:flex}.integration-sub-tab{color:var(--text-secondary,#888);background:var(--surface-2,#f5f5f5);border:1px solid var(--border,#e5e5e5);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s}.integration-sub-tab:hover{color:var(--text-primary,#333);background:var(--surface-1,#eee)}.integration-sub-tab.active{color:var(--primary,#2563eb);border-color:var(--primary,#2563eb);background:#2563eb14}.admin-user-actions{align-items:center;gap:8px;display:flex}.admin-badge{color:var(--primary,#2563eb);background:#2563eb14;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.asset-name-cell{align-items:center;gap:6px;display:flex}.ninja-link{color:var(--text-secondary,#888);flex-shrink:0;align-items:center;display:inline-flex}.ninja-link:hover{color:var(--primary,#2563eb)}.asset-os{color:var(--text-secondary,#888);margin-top:2px;font-size:11px}.asset-status-chip{border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.asset-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.asset-online{color:#16a34a;background:#22c55e1f}.asset-online .asset-status-dot{background:#22c55e;box-shadow:0 0 4px #22c55e80}.asset-offline{color:#dc2626;background:#ef44441a}.asset-offline .asset-status-dot{background:#ef4444}.td-specs{color:var(--text-secondary,#666);max-width:280px;font-size:12px}
