:root,[data-theme=light]{--bg-page: #f5f5f5;--bg-card: #ffffff;--bg-main: #fafafa;--bg-header: rgba(250, 250, 250, .1);--bg-sidebar: #ffffff;--bg-input: #ffffff;--bg-hover: #f0f0f0;--bg-active: #e8e8e8;--bg-avatar: #e0e0e0;--text-primary: #1a1a1a;--text-secondary: #666666;--border: #e5e5e5;--focus-ring: #2563eb;--btn-primary: #2563eb;--shadow-card: 0 4px 20px rgba(0, 0, 0, .08);--shadow-modal: 0 20px 40px rgba(0, 0, 0, .15);--overlay: rgba(0, 0, 0, .4);--error-bg: #fef2f2;--error-text: #b91c1c;--success-bg: #f0fdf4;--success-text: #166534;--link: #2563eb}[data-theme=dark]{--bg-page: #171717;--bg-card: #262626;--bg-main: #1c1c1c;--bg-header: rgba(28, 28, 28, .1);--bg-sidebar: #262626;--bg-input: #2a2a2a;--bg-hover: #333333;--bg-active: #404040;--bg-avatar: #404040;--text-primary: #f5f5f5;--text-secondary: #a3a3a3;--border: #404040;--focus-ring: #3b82f6;--btn-primary: #3b82f6;--shadow-card: 0 4px 20px rgba(0, 0, 0, .4);--shadow-modal: 0 20px 40px rgba(0, 0, 0, .5);--overlay: rgba(0, 0, 0, .6);--error-bg: #450a0a;--error-text: #fca5a5;--success-bg: #052e16;--success-text: #86efac;--link: #60a5fa}*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-page);color:var(--text-primary)}#root{min-height:100vh}button{font-family:inherit}.confirm-modal-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1001;padding:1rem}.confirm-modal{background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);max-width:440px;width:100%;overflow:hidden}.confirm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.confirm-modal-header h2{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.confirm-modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;transition:color .15s,background .15s}.confirm-modal-close:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.confirm-modal-close:disabled{opacity:.6;cursor:not-allowed}.confirm-modal-body{padding:1.25rem;font-size:.95rem;color:var(--text-secondary);line-height:1.5}.confirm-modal-footer{display:flex;gap:.5rem;justify-content:flex-end;padding:1rem 1.25rem;border-top:1px solid var(--border)}.confirm-modal-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s,color .15s;font-family:inherit}.confirm-modal-btn:disabled{opacity:.7;cursor:not-allowed}.confirm-modal-btn--cancel{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.confirm-modal-btn--cancel:hover:not(:disabled){background:var(--bg-active)}.confirm-modal-btn--confirm{background:var(--error-text);color:#fff;border:none}.confirm-modal-btn--confirm:hover:not(:disabled){opacity:.9}.confirm-modal-btn--confirm.confirm-modal-btn--primary{background:var(--btn-primary)}.profile-modal-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.profile-modal{width:100%;max-width:22rem;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);overflow:hidden}.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.profile-modal-header h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.profile-modal-close{padding:.25rem;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px;transition:color .15s,background .15s}.profile-modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.profile-modal-form{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.profile-modal-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.profile-modal-label--muted{color:var(--text-secondary)}.profile-modal-input{padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s}.profile-modal-input:focus{border-color:var(--focus-ring)}.profile-modal-input--readonly{opacity:.85;cursor:default}.profile-modal-message{padding:.6rem .75rem;font-size:.875rem;border-radius:8px}.profile-modal-message--error{background:var(--error-bg);color:var(--error-text)}.profile-modal-message--success{background:var(--success-bg);color:var(--success-text)}.profile-modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.profile-modal-footer{padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--border)}.profile-modal-signout{padding:.5rem 0;font-size:.875rem;color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:color .15s,background .15s}.profile-modal-signout:hover{color:var(--text-primary);text-decoration:underline}.profile-modal-cancel{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.profile-modal-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.profile-modal-submit{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.profile-modal-submit:hover:not(:disabled){opacity:.9}.profile-modal-submit:disabled{opacity:.7;cursor:not-allowed}.user-panel{display:flex;flex-direction:row;align-items:center;gap:.25rem}.user-panel-trigger{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;padding:.5rem;font-size:.875rem;color:var(--text-primary);background:none;border:none;border-radius:8px;cursor:pointer;text-align:left;transition:background .15s}.user-panel-trigger:hover{background:var(--bg-hover)}.user-panel-avatar{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;background:var(--bg-avatar);color:var(--text-primary);border-radius:50%;flex-shrink:0}.user-panel-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-panel-theme{flex-shrink:0;padding:.5rem .75rem;font-size:1.1rem;background:var(--bg-hover);border:none;border-radius:8px;cursor:pointer;transition:background .15s}.user-panel-theme:hover{background:var(--bg-active)}.sidebar{display:flex;flex-direction:column;width:14rem;height:100%;background:var(--bg-sidebar);border-right:1px solid var(--border);overflow-y:auto}.sidebar-header{padding:1.25rem 1.5rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.025em}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav-group{display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem}.sidebar-nav-group-label{padding:.25rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, var(--text-secondary))}.sidebar-link{padding:.5rem .75rem;font-size:.95rem;color:var(--text-secondary);text-decoration:none;border-radius:8px;transition:background .15s,color .15s}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link--active{background:var(--bg-active);color:var(--text-primary);font-weight:500}.sidebar-seed{padding:.75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.35rem}.sidebar-seed-row{display:flex;gap:.35rem}.sidebar-seed-btn{width:100%;padding:.5rem .75rem;font-size:.85rem;color:var(--text-secondary);background:var(--bg-hover);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.sidebar-seed-btn:hover:not(:disabled){background:var(--bg-active);color:var(--text-primary)}.sidebar-seed-btn:disabled{opacity:.7;cursor:not-allowed}.sidebar-seed-row .sidebar-seed-btn{flex:1;min-width:0;width:auto}.sidebar-seed-btn--danger:hover:not(:disabled){background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.sidebar-seed-msg{margin:0;font-size:.75rem;line-height:1.3}.sidebar-seed-msg--ok{color:var(--success-text)}.sidebar-seed-msg--err{color:var(--error-text)}.sidebar-footer{padding:1rem .75rem;border-top:1px solid var(--border)}.app-layout{display:flex;height:100vh;overflow:hidden}.app-main{flex:1;overflow-y:auto;background:var(--bg-main)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg-page, #f5f5f5)}.login-card{width:100%;max-width:24rem;padding:2rem;background:var(--bg-card, #fff);border-radius:12px;box-shadow:var(--shadow-card, 0 4px 20px rgba(0, 0, 0, .08))}.login-title{margin:0 0 .25rem;font-size:1.5rem;font-weight:600;color:var(--text-primary);text-align:center}.login-subtitle{margin:0 0 1.5rem;font-size:.9rem;color:var(--text-secondary);text-align:center}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.login-input{padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border, #e0e0e0);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--focus-ring, #2563eb)}.login-message{padding:.6rem .75rem;font-size:.875rem;border-radius:8px}.login-message--error{background:var(--error-bg, #fef2f2);color:var(--error-text, #b91c1c)}.login-message--success{background:var(--success-bg, #f0fdf4);color:var(--success-text, #166534)}.login-submit{padding:.65rem 1rem;font-size:1rem;font-weight:500;color:#fff;background:var(--btn-primary, #2563eb);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.login-submit:hover:not(:disabled){opacity:.9}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0 0;font-size:.8rem;color:var(--text-secondary)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-google{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.65rem 1rem;font-size:1rem;font-weight:500;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.login-google:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-secondary)}.login-google:disabled{opacity:.7;cursor:not-allowed}.login-google-icon{display:flex;align-items:center;justify-content:center}.login-toggle{margin-top:1rem;padding:0;font-size:.875rem;color:var(--link, #2563eb);background:none;border:none;cursor:pointer;text-align:center;width:100%}.login-toggle:hover{text-decoration:underline}.page-header{position:sticky;top:0;z-index:10;background:var(--bg-header);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;flex-direction:column;transition:background-color .2s ease}.page-header-top{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;gap:1rem;flex-wrap:wrap}.page-header-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary);line-height:1.2}.page-header-actions{display:flex;align-items:center;gap:.75rem}.page-header-filters{padding:0 1.5rem 1.5rem;display:flex;align-items:center;justify-content:flex-end;gap:1rem;flex-wrap:wrap}.dashboard-content{padding:1.5rem}.dashboard-placeholder{margin:0;font-size:.95rem;color:var(--text-secondary)}.assignee-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;color:#fff;flex-shrink:0;line-height:1}.assignee-avatar--sm{width:1.5rem;height:1.5rem;font-size:.6rem}.assignee-avatar--md{width:1.75rem;height:1.75rem;font-size:.7rem}.assignee-avatar--color-0{background:#5b7c99}.assignee-avatar--color-1{background:#7d6b9a}.assignee-avatar--color-2{background:#9a6b7d}.assignee-avatar--color-3{background:#6b9a7d}.assignee-avatar--color-4{background:#9a8f6b}.assignee-avatar--color-5{background:#6b8f9a}.assignee-avatar--color-6{background:#c97b58}.assignee-avatar--color-7{background:#5896c9}.contact-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;color:#fff;flex-shrink:0;line-height:1;overflow:hidden}.contact-avatar-img{width:100%;height:100%;object-fit:cover}.contact-avatar--sm{width:1.5rem;height:1.5rem;font-size:.6rem}.contact-avatar--md{width:1.75rem;height:1.75rem;font-size:.7rem}.contact-avatar--color-0{background:#5b7c99}.contact-avatar--color-1{background:#7d6b9a}.contact-avatar--color-2{background:#9a6b7d}.contact-avatar--color-3{background:#6b9a7d}.contact-avatar--color-4{background:#9a8f6b}.contact-avatar--color-5{background:#6b8f9a}.contact-avatar--color-6{background:#c97b58}.contact-avatar--color-7{background:#5896c9}.assignee-select{position:relative;min-width:150px}.assignee-select-trigger{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);cursor:pointer;text-align:left;font-family:inherit;transition:border-color .15s,box-shadow .15s}.assignee-select-trigger:hover{border-color:var(--text-secondary)}.assignee-select-trigger:focus{outline:none;border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.assignee-select-trigger-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.assignee-select-trigger-avatar{flex-shrink:0}.assignee-select-chevron{flex-shrink:0;font-size:.6rem;opacity:.7}.assignee-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;margin:0;padding:.25rem 0;list-style:none;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-modal, 0 8px 24px rgba(0, 0, 0, .12));max-height:280px;overflow-y:auto;z-index:100}.assignee-select-option{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;cursor:pointer;font-size:.9rem;color:var(--text-primary);transition:background .1s}.assignee-select-option:hover{background:var(--bg-hover)}.assignee-select-option--selected{background:var(--focus-ring-subtle, rgba(13, 110, 253, .08))}.assignee-select-option-avatar{flex-shrink:0}.assignee-select-option-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-search-suggest{position:relative;flex:1;min-width:140px}.contact-search-suggest-input-wrap{position:relative;display:flex;align-items:center}.contact-search-suggest-input{width:100%;padding:.5rem 2rem .5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.contact-search-suggest-input::placeholder{color:var(--text-secondary)}.contact-search-suggest-input:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle, rgba(37, 99, 235, .15))}.contact-search-suggest-input:disabled{opacity:.7;cursor:not-allowed}.contact-search-suggest-open .contact-search-suggest-input{border-radius:8px 8px 0 0}.contact-search-suggest-clear{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);padding:.2rem .4rem;font-size:1.1rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px}.contact-search-suggest-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.contact-search-suggest-list{position:absolute;top:100%;left:0;right:0;margin:0;padding:.25rem 0;list-style:none;background:var(--bg-card);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;box-shadow:var(--shadow-modal, 0 8px 24px rgba(0, 0, 0, .12));max-height:220px;overflow-y:auto;z-index:100}.contact-search-suggest-option{padding:.5rem .75rem;font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:background .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-search-suggest-option:hover,.contact-search-suggest-option--highlighted{background:var(--bg-hover)}.contact-search-suggest-option--highlighted{background:var(--focus-ring-subtle, rgba(37, 99, 253, .1))}.contact-search-suggest-empty{padding:.6rem .75rem;font-size:.875rem;color:var(--text-secondary);cursor:default}.contact-search-suggest-chip{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);min-height:2.25rem}.contact-search-suggest-chip-name{flex:1;min-width:0;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-search-suggest-chip-clear{flex-shrink:0;padding:.15rem .35rem;font-size:1rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px}.contact-search-suggest-chip-clear:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.contact-search-suggest-chip-clear:disabled{opacity:.6;cursor:not-allowed}.inbox-page{display:flex;flex-direction:column;height:100%;min-height:0}.inbox-content{flex:1;min-height:0;padding:1.5rem;display:flex;flex-direction:column;overflow:hidden}.inbox-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}.inbox-layout{flex:1;min-height:0;display:flex;gap:0;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-card)}.inbox-list-panel{width:320px;flex-shrink:0;min-height:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.inbox-list-search-wrap{flex-shrink:0;padding:.5rem .75rem;border-bottom:1px solid var(--border)}.inbox-list-search{width:100%;padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-main);color:var(--text-primary)}.inbox-list-search::placeholder{color:var(--text-secondary)}.inbox-list-search:focus{outline:none;border-color:var(--focus-ring, #0d6efd);box-shadow:0 0 0 2px var(--focus-ring-subtle, rgba(13, 110, 253, .2))}.inbox-filter-assignee{min-width:140px}.inbox-loading{margin:0;padding:1rem;color:var(--text-secondary);font-size:.9rem}.inbox-empty-list{padding:1.5rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.inbox-empty-hint{margin-top:.5rem;font-size:.8rem;opacity:.9}.inbox-list{flex:1;min-height:0;margin:0;padding:0;list-style:none;overflow-y:auto}.inbox-list-item{display:flex;flex-direction:column;align-items:stretch;gap:.35rem;width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;color:var(--text-primary);font-family:inherit}.inbox-list-item:hover{background:var(--bg-hover)}.inbox-list-item--active{background:var(--bg-active)}.inbox-list-item--unreplied{background:var(--inbox-unreplied-bg, rgba(13, 110, 253, .06))}.inbox-list-item--unreplied:hover{background:var(--inbox-unreplied-bg-hover, rgba(13, 110, 253, .1))}.inbox-list-item--active.inbox-list-item--unreplied{background:var(--bg-active)}.inbox-list-item-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.inbox-list-item-avatar{flex-shrink:0}.inbox-list-item--contact .inbox-list-item-name{flex:1;min-width:0}.inbox-list-item-assignee{flex-shrink:0}.inbox-list-item-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-size:.75rem;color:var(--text-secondary)}.inbox-list-item-stat{white-space:nowrap}.inbox-list-item-stat--replied{color:var(--success-text, #2e7d32)}.inbox-list-item-head{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.inbox-list-item-name{font-weight:600;font-size:.95rem}.inbox-list-item-preview{margin:.25rem 0 0;font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inbox-list-item-time{display:block;margin-top:.2rem;font-size:.75rem;color:var(--text-secondary)}.inbox-badge{font-size:.7rem;padding:.15rem .4rem;border-radius:4px;font-weight:500}.inbox-badge--email{background:var(--bg-hover);color:var(--text-secondary)}.inbox-badge--whatsapp{background:#e8f5e9;color:#2e7d32}[data-theme=dark] .inbox-badge--whatsapp{background:#1b3d1f;color:#81c784}.inbox-thread-panel{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.inbox-right-panel{width:33.333%;flex-shrink:0;min-height:0;border-left:1px solid var(--border);position:relative;overflow:hidden;background:var(--bg-main)}.inbox-right-panel-list-wrap{position:absolute;inset:0;display:flex;flex-direction:column;min-height:0;background:var(--bg-main);z-index:1;transition:transform .3s ease}.inbox-right-panel--detail-open .inbox-right-panel-list-wrap{transform:translate(-100%)}.inbox-right-panel-detail{position:absolute;inset:0;display:flex;flex-direction:column;min-height:0;background:var(--bg-main);z-index:2;transform:translate(100%);transition:transform .3s ease;overflow:hidden}.inbox-right-panel--detail-open .inbox-right-panel-detail{transform:translate(0)}.inbox-right-panel-detail-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem;color:var(--text-secondary);font-size:.9rem;text-align:center}.inbox-right-panel-detail-header{flex-shrink:0;padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.inbox-right-panel-detail-back{align-self:flex-start;padding:.25rem 0;font-size:.85rem;color:var(--link, #0d6efd);background:none;border:none;cursor:pointer;font-family:inherit}.inbox-right-panel-detail-back:hover{text-decoration:underline}.inbox-right-panel-detail-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.inbox-right-panel-detail-body{flex:1;min-height:0;overflow-y:auto;padding:1rem}.inbox-right-panel-meta{margin-bottom:1.25rem}.inbox-right-panel-meta-list{margin:0;display:grid;gap:.35rem 1rem}.inbox-right-panel-meta-row{display:flex;gap:.5rem;font-size:.875rem}.inbox-right-panel-meta-row dt{margin:0;color:var(--text-secondary);min-width:5rem}.inbox-right-panel-meta-row dd{margin:0;color:var(--text-primary)}.inbox-right-panel-notes{margin:.75rem 0 0;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.inbox-right-panel-activity-title{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:var(--text-primary)}.inbox-right-panel-activity-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.75rem}.inbox-right-panel-activity-item{font-size:.85rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.inbox-right-panel-activity-item:last-child{border-bottom:none}.inbox-right-panel-activity-date{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.inbox-right-panel-activity-text{margin:0;color:var(--text-primary);line-height:1.4}.inbox-right-panel-activity-image-wrap{margin-top:.35rem}.inbox-right-panel-activity-image{width:100%;max-width:100%;height:auto;border-radius:8px;display:block;border:1px solid var(--border)}.inbox-right-panel-activity-pexels{display:block;margin-top:.25rem;font-size:.7rem;color:var(--text-secondary)}.inbox-right-panel-header{padding:1rem;border-bottom:1px solid var(--border);flex-shrink:0}.inbox-right-panel-title{margin:0;font-size:.95rem;font-weight:600;color:var(--text-primary)}.inbox-right-panel-subtitle{margin:.35rem 0 0;font-size:.8rem;color:var(--text-secondary)}.inbox-right-panel-list{flex:1;min-height:0;margin:0;padding:.75rem 1rem;list-style:none;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.inbox-right-panel-card-wrap{flex-shrink:0}.inbox-right-panel-card{display:block;width:100%;padding:.85rem 1rem;text-align:left;font-family:inherit;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .2s,box-shadow .2s;box-shadow:var(--shadow-card, 0 1px 3px rgba(0, 0, 0, .06))}.inbox-right-panel-card:hover{border-color:var(--focus-ring, #0d6efd);box-shadow:0 4px 12px #00000014}.inbox-right-panel-card--selected{border-color:var(--btn-primary, #0d6efd);background:var(--bg-active);box-shadow:0 2px 8px #0d6efd33}.inbox-right-panel-card-name{font-size:.9rem;font-weight:600;color:var(--text-primary);line-height:1.3}.inbox-right-panel-card-meta{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;font-size:.75rem;color:var(--text-secondary)}.inbox-right-panel-card-status{padding:.15rem .45rem;border-radius:6px;background:var(--bg-hover);font-weight:500;color:var(--text-secondary)}.inbox-right-panel-card--selected .inbox-right-panel-card-status{background:#ffffff40;color:inherit}.inbox-right-panel-card-date{flex-shrink:0}.inbox-right-panel-item{padding:.65rem 1rem;border-bottom:1px solid var(--border);transition:background .15s}.inbox-right-panel-item:hover{background:var(--bg-hover)}.inbox-right-panel-item-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.inbox-right-panel-item-meta{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;font-size:.75rem;color:var(--text-secondary)}.inbox-right-panel-item-status{padding:.1rem .4rem;border-radius:4px;background:var(--bg-hover);font-weight:500}.inbox-right-panel-item-date{flex-shrink:0}.inbox-thread-empty{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:.95rem}.inbox-thread{flex:1;display:flex;flex-direction:column;min-height:0}.inbox-thread-header{padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.inbox-thread-title{display:flex;align-items:center;gap:.5rem}.inbox-thread-actions{display:flex;gap:.5rem}.inbox-link-contact-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.inbox-link-contact-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.inbox-archive-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer}.inbox-archive-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.inbox-archive-btn:disabled{opacity:.7;cursor:not-allowed}.inbox-messages-wrap{flex:1;min-height:0;overflow-y:auto;padding:1rem}.inbox-messages{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.75rem}.inbox-msg{max-width:85%;padding:.6rem .9rem;border-radius:12px;font-size:.9rem;line-height:1.45}.inbox-msg-inner{position:relative;padding-right:1.5rem}.inbox-msg-raw-btn{position:absolute;top:0;right:0;width:1.5rem;height:1.5rem;padding:0;display:flex;align-items:center;justify-content:center;border:none;border-radius:4px;background:transparent;color:inherit;opacity:.6;cursor:pointer;transition:opacity .15s,background .15s}.inbox-msg-raw-btn:hover{opacity:1;background:#00000014}.inbox-msg--outbound .inbox-msg-raw-btn:hover{background:#fff3}.inbox-msg--inbound{align-self:flex-start;background:var(--bg-hover);border-bottom-left-radius:4px}.inbox-msg--outbound{align-self:flex-end;background:var(--btn-primary);color:#fff;border-bottom-right-radius:4px}.inbox-msg-subject{font-weight:600;font-size:.95rem;margin-bottom:.35rem;line-height:1.3;word-break:break-word}.inbox-msg--outbound .inbox-msg-subject{color:#fffffff2}.inbox-msg-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.inbox-msg-badge{font-size:.7rem;opacity:.9}.inbox-msg-meta time{font-size:.75rem;opacity:.85}.inbox-msg--outbound .inbox-msg-meta time{color:#ffffffe6}.inbox-msg-body{word-break:break-word}.inbox-msg-body table{border-collapse:collapse;width:100%;max-width:100%;margin:.5rem 0;font-size:inherit;empty-cells:show;border:1px solid var(--border)}.inbox-msg-body thead,.inbox-msg-body tbody{display:table-row-group}.inbox-msg-body tr{display:table-row}.inbox-msg-body th,.inbox-msg-body td{padding:.5rem .75rem;border:1px solid var(--border);text-align:left;vertical-align:top;word-break:break-word}.inbox-msg-body th{font-weight:600;background:var(--bg-hover);color:var(--text-primary)}.inbox-msg-body tbody tr:nth-child(2n){background:var(--inbox-table-row-alt, rgba(0, 0, 0, .02))}.inbox-msg-body tbody tr:nth-child(odd){background:var(--bg-card)}[data-theme=dark] .inbox-msg-body tbody tr:nth-child(2n){background:var(--inbox-table-row-alt, rgba(255, 255, 255, .04))}.inbox-msg--outbound .inbox-msg-body table{border-color:#ffffff4d}.inbox-msg--outbound .inbox-msg-body th,.inbox-msg--outbound .inbox-msg-body td{border-color:#ffffff40}.inbox-msg--outbound .inbox-msg-body th{background:#fff3}.inbox-msg--outbound .inbox-msg-body tbody tr:nth-child(2n){background:#ffffff1a}.inbox-msg--outbound .inbox-msg-body tbody tr:nth-child(odd){background:transparent}.inbox-msg-body{overflow-x:auto;overflow-y:visible}.inbox-msg-body img{max-width:100%;height:auto;display:block}.inbox-msg-body table{white-space:normal}.inbox-msg-attachments{margin:.5rem 0 0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:.35rem}.inbox-msg-attachment{margin:0;padding:0}.inbox-msg-attachment-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;font-size:.8rem;color:var(--link, #0d6efd);background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s;max-width:100%}.inbox-msg-attachment-btn:hover:not(:disabled){background:var(--bg-active);border-color:var(--focus-ring)}.inbox-msg-attachment-btn:disabled{opacity:.7;cursor:wait}.inbox-msg-attachment-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-msg-attachment-size{flex-shrink:0;font-size:.75rem;color:var(--text-secondary)}.inbox-reply{padding:1rem;border-top:1px solid var(--border);background:var(--bg-main)}.inbox-reply-channel{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.5rem}.inbox-reply-channel label{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-secondary)}.inbox-reply-select{padding:.35rem .5rem;font-size:.85rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-input);color:var(--text-primary)}.inbox-reply-quick-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.inbox-reply-quick-link{padding:.35rem .65rem;font-size:.8rem;font-weight:500;color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.inbox-reply-quick-link:hover{color:var(--text-primary);border-color:var(--focus-ring);background:var(--bg-card)}.inbox-reply-input-wrap{display:flex;gap:.5rem;align-items:flex-end}.inbox-reply-input{flex:1;padding:.6rem .75rem;font-size:.9rem;font-family:inherit;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);resize:vertical;min-height:60px}.inbox-reply-input:focus{outline:none;border-color:var(--focus-ring)}.inbox-reply-send{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.inbox-reply-send:hover:not(:disabled){opacity:.9}.inbox-reply-send:disabled{opacity:.6;cursor:not-allowed}.inbox-fetch-btn,.inbox-new-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.inbox-fetch-btn:hover:not(:disabled),.inbox-new-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.inbox-fetch-btn:disabled{opacity:.7;cursor:not-allowed}.inbox-new-btn--primary{color:#fff;background:var(--btn-primary);border-color:var(--btn-primary)}.inbox-new-btn--primary:hover{opacity:.9}.inbox-filter-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.inbox-filter-btn svg{width:18px;height:18px}.inbox-filter-btn:hover{background:var(--bg-hover)}.inbox-filter-btn.active{background:var(--bg-hover);border-color:var(--text-secondary)}.inbox-reply-integration{margin-left:.5rem}.inbox-raw-backdrop{position:fixed;inset:0;background:var(--overlay, rgba(0, 0, 0, .5));display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.inbox-raw-modal{width:100%;max-width:36rem;max-height:85vh;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal, 0 20px 40px rgba(0, 0, 0, .2));overflow:hidden;display:flex;flex-direction:column}.inbox-raw-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.inbox-raw-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.inbox-raw-close{padding:.25rem;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px}.inbox-raw-close:hover{color:var(--text-primary);background:var(--bg-hover)}.inbox-raw-body{margin:0;padding:1rem;overflow:auto;flex:1;min-height:0;font-size:.8rem;line-height:1.4;color:var(--text-primary);background:var(--bg-main);white-space:pre-wrap;word-break:break-word}.group-detail-modal{width:100%;max-width:90rem;height:85vh;max-height:85vh;display:flex;flex-direction:column}.group-detail-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.group-detail-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.group-detail-header-actions .contact-form-close{margin-left:.25rem}.group-detail-body{flex:1;min-height:0;display:flex;gap:0;overflow:hidden}.group-detail-col-left{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow-y:auto;padding:1rem 1.25rem;gap:1rem;border-right:1px solid var(--border)}.group-detail-col-right{width:45%;min-width:360px;flex-shrink:0;min-height:0;overflow:hidden;display:flex;flex-direction:column}.group-detail-col-right .inbox-right-panel{width:100%;flex:1;min-height:0}.group-detail-subpanel{background:var(--bg-main);border:1px solid var(--border);border-radius:10px;padding:1rem}.group-detail-subpanel-title{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:var(--text-primary)}.group-detail-description{width:100%;padding:.5rem .65rem;font-size:.95rem;font-family:inherit;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;resize:vertical;min-height:4rem;box-sizing:border-box}.group-detail-description:focus{border-color:var(--focus-ring)}.group-detail-description::placeholder{color:var(--text-secondary)}.group-detail-members-loading,.group-detail-members-empty{margin:0;font-size:.875rem;color:var(--text-secondary)}.group-detail-members-list{list-style:none;margin:0;padding:0;border:1px solid var(--border);border-radius:8px;overflow:hidden}.group-detail-member-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-bottom:1px solid var(--border);font-size:.9rem}.group-detail-member-item:last-child{border-bottom:none}.group-detail-member-info{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:.15rem}.group-detail-member-name{font-weight:500;color:var(--text-primary)}.group-detail-member-name--link{display:inline-block;margin:0;padding:0;font:inherit;color:var(--link-color, #0d6efd);background:none;border:none;cursor:pointer;text-align:left;text-decoration:none}.group-detail-member-name--link:hover{text-decoration:underline}.group-detail-member-contact-detail{font-size:.8rem;color:var(--text-secondary)}.group-detail-member-contact-link{color:var(--link-color, #0d6efd);text-decoration:none}.group-detail-member-contact-link:hover{text-decoration:underline}.group-detail-member-role-input{flex:1 1 0;min-width:0;padding:.25rem .5rem;font-size:.85rem}.group-detail-member-role{font-size:.8rem;color:var(--text-secondary);font-style:italic}.group-detail-remove-btn{padding:.2rem .5rem;font-size:.75rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:background .15s,color .15s}.group-detail-remove-btn:hover:not(:disabled){background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.group-detail-remove-btn:disabled{opacity:.7;cursor:not-allowed}.group-detail-remove-btn--icon{flex-shrink:0;width:1.75rem;height:1.75rem;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1}.group-detail-add-contact{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem}.group-detail-add-select{flex:1;min-width:140px}.group-detail-add-role{flex:0 0 100px;min-width:80px}.group-detail-add-btn{flex-shrink:0;padding:.4rem .75rem;font-size:.875rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer}.group-detail-add-btn:hover:not(:disabled){opacity:.9}.group-detail-add-btn:disabled{opacity:.6;cursor:not-allowed}.group-detail-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem}.group-detail-actions-right{display:flex;gap:.5rem}.group-detail-actions .contacts-card-btn--danger{order:-1}.contact-form-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:modal-backdrop-in .2s ease-out}.contact-form-backdrop.closing{animation:modal-backdrop-out .2s ease-in forwards}.contact-form-backdrop--stacked{top:24px;left:24px}.contact-form-modal{width:100%;max-width:90rem;max-height:90vh;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);overflow:hidden;display:flex;flex-direction:column;animation:modal-content-in .2s ease-out}.contact-form-modal.closing{animation:modal-content-out .2s ease-in forwards}.contact-form-modal--stacked{margin-top:24px;margin-left:24px}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes modal-content-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes modal-content-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.97)}}.contact-form-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.contact-form-header h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.contact-form-close{padding:.25rem;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px;transition:color .15s,background .15s}.contact-form-close:hover{color:var(--text-primary);background:var(--bg-hover)}.contact-form-body{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.contact-form-section{display:flex;flex-direction:column;gap:.6rem}.contact-form-section-head{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.contact-form-add-btn{font-size:.75rem;font-weight:500;color:var(--link);background:none;border:none;cursor:pointer;padding:.2rem .4rem;border-radius:4px}.contact-form-add-btn:hover{text-decoration:underline}.contact-form-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.contact-form-label--full{width:100%}.contact-form-label--checkbox{flex-direction:row;align-items:center;gap:.5rem}.contact-form-label--checkbox input[type=checkbox]{width:auto;margin:0}.contact-form-input{padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s}.contact-form-input:focus{border-color:var(--focus-ring)}.contact-form-select{cursor:pointer;appearance:auto}.contact-form-input--flex{flex:1;min-width:0}.contact-form-textarea{display:block;width:100%;min-height:8rem;resize:vertical;line-height:1.45}.contact-form-notes-hint{margin:.35rem 0 0;font-size:.8125rem;color:var(--color-text-muted, #6b7280)}.contact-form-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.contact-form-check{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary);white-space:nowrap;cursor:pointer}.contact-form-referral-options{display:flex;flex-wrap:wrap;gap:.75rem}.contact-form-radio{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-primary);cursor:pointer}.contact-form-remove{padding:.25rem .5rem;font-size:1rem;line-height:1;color:var(--text-secondary);background:var(--bg-hover);border:none;border-radius:4px;cursor:pointer}.contact-form-remove:hover{color:var(--text-primary);background:var(--bg-active)}.contact-form-address{border:1px solid var(--border);border-radius:8px;padding:.6rem .75rem;margin:0}.contact-form-address-legend{font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;padding:0 .35rem}.contact-form-address-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.4rem}.contact-form-address-grid .contact-form-label--full{grid-column:1 / -1}.contact-form-message{padding:.6rem .75rem;font-size:.875rem;border-radius:8px}.contact-form-message--error{background:var(--error-bg);color:var(--error-text)}.contact-form-message--success{background:var(--success-bg);color:var(--success-text)}.contact-form-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);flex-shrink:0}.contact-form-cancel{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.contact-form-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.contact-form-submit{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.contact-form-submit:hover:not(:disabled){opacity:.9}.contact-form-submit:disabled{opacity:.7;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background:var(--overlay, rgba(0, 0, 0, .5));display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.merge-contact-modal{width:100%;max-width:28rem;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal, 0 20px 40px rgba(0, 0, 0, .15));padding:1.25rem}.merge-contact-modal .modal-title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.merge-contact-desc{margin:0 0 1.25rem;font-size:.9rem;color:var(--text-secondary);line-height:1.45}.merge-contact-list{margin:0 0 1rem;padding:0;border:none}.merge-contact-legend{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;display:block}.merge-contact-option{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;margin-bottom:.35rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.merge-contact-option:hover{background:var(--bg-hover)}.merge-contact-option:has(input:checked){border-color:var(--focus-ring);background:var(--focus-ring-subtle, rgba(13, 110, 253, .08))}.merge-contact-option input{flex-shrink:0}.merge-contact-name{font-weight:600;color:var(--text-primary)}.merge-contact-meta{font-size:.85rem;color:var(--text-secondary);margin-left:auto}.merge-contact-error{margin:0 0 1rem;padding:.5rem .75rem;font-size:.875rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.merge-contact-modal .modal-actions{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.merge-contact-modal .modal-btn{padding:.5rem 1rem;font-size:.9rem;border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.merge-contact-modal .modal-btn--secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.merge-contact-modal .modal-btn--secondary:hover{background:var(--bg-hover)}.merge-contact-modal .modal-btn--primary{background:var(--btn-primary);color:#fff;border:none;font-weight:500}.merge-contact-modal .modal-btn--primary:hover:not(:disabled){opacity:.9}.merge-contact-modal .modal-btn--primary:disabled{opacity:.7;cursor:not-allowed}.bulk-edit-contact-modal{width:100%;max-width:28rem;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal, 0 20px 40px rgba(0, 0, 0, .15));padding:1.25rem}.bulk-edit-contact-modal .modal-title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.bulk-edit-contact-desc{margin:0 0 1.25rem;font-size:.9rem;color:var(--text-secondary);line-height:1.45}.bulk-edit-contact-field{margin-bottom:1rem}.bulk-edit-contact-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;margin-bottom:.2rem}.bulk-edit-contact-select{width:100%;padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-page);color:var(--text-primary)}.bulk-edit-contact-select:focus{outline:none;border-color:var(--focus-ring)}.bulk-edit-contact-error{margin:0 0 1rem;padding:.5rem .75rem;font-size:.875rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.bulk-edit-contact-modal .modal-actions{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.bulk-edit-contact-modal .modal-btn{padding:.5rem 1rem;font-size:.9rem;border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.bulk-edit-contact-modal .modal-btn--secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.bulk-edit-contact-modal .modal-btn--secondary:hover{background:var(--bg-hover)}.bulk-edit-contact-modal .modal-btn--primary{background:var(--btn-primary);color:#fff;border:none;font-weight:500}.bulk-edit-contact-modal .modal-btn--primary:hover:not(:disabled){opacity:.9}.bulk-edit-contact-modal .modal-btn--primary:disabled{opacity:.7;cursor:not-allowed}.contacts-table-wrap{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden}.contacts-table-toolbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-main)}.contacts-table-page-size{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.contacts-table-page-size select{padding:.35rem .5rem;font-size:.875rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);cursor:pointer}.contacts-table-count{font-size:.875rem;color:var(--text-secondary)}.contacts-table-scroll{overflow-x:auto}.contacts-table{width:100%;border-collapse:collapse;font-size:.9rem}.contacts-table-th,.contacts-table-td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.contacts-table-th{background:var(--bg-main);font-weight:600;color:var(--text-primary);white-space:nowrap}.contacts-table-th--checkbox{width:2.5rem;min-width:2.5rem;padding:.5rem}.contacts-table-check-all,.contacts-table-check{display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0}.contacts-table-check-all input,.contacts-table-check input{width:1rem;height:1rem;cursor:pointer}.contacts-table-td--checkbox{width:2.5rem;min-width:2.5rem;padding:.5rem;vertical-align:middle}.contacts-table-th--thumb{width:64px;min-width:64px}.contacts-table-th-content{display:flex;flex-direction:column;gap:.35rem}.contacts-table-th-label{display:block}.contacts-table-sort{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem 0;font:inherit;font-weight:600;color:var(--text-primary);background:none;border:none;cursor:pointer;text-align:left;transition:color .15s}.contacts-table-sort:hover,.contacts-table-sort.active{color:var(--focus-ring)}.contacts-table-sort-icon{font-size:.75em;opacity:.9}.contacts-table-filter-input,.contacts-table-filter-select{padding:.35rem .5rem;font-size:.8rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);width:100%;max-width:140px}.contacts-table-filter-input:focus,.contacts-table-filter-select:focus{outline:none;border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.contacts-table-assignee-select{max-width:140px}.contacts-table-th--extra{font-weight:600}.contacts-table-th--actions{width:1%;white-space:nowrap}.contacts-table-row{cursor:pointer;transition:background .15s}.contacts-table-row:hover{background:var(--bg-hover)}.contacts-table-row:focus{outline:none}.contacts-table-row:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-2px}.contacts-table-td--thumb{width:64px;min-width:64px;padding:.4rem}.contacts-table-name-wrap{display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap}.contacts-table-avatar{width:48px;height:48px;border-radius:50%}.contacts-table-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;color:var(--text-secondary)}.contacts-table-td--updated{white-space:nowrap;color:var(--text-secondary);font-size:.85rem}.contacts-table-td--groups{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;color:var(--text-secondary)}.contacts-table-td--actions{white-space:nowrap}.contacts-table-actions{display:flex;gap:.35rem;flex-wrap:wrap}.contacts-table-btn{padding:.3rem .6rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.contacts-table-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.contacts-table-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.contacts-table-loading,.contacts-table-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.contacts-table-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.contacts-table-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.contacts-table-pagination-btn{padding:.4rem .75rem;font-size:.875rem;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s}.contacts-table-pagination-btn:hover:not(:disabled){background:var(--bg-hover)}.contacts-table-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.contacts-table-pagination-info{font-size:.875rem;color:var(--text-secondary)}.contacts-content{padding:1.5rem}.contacts-filter-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.contacts-filter-btn svg{width:18px;height:18px}.contacts-filter-btn:hover{background:var(--bg-hover)}.contacts-filter-btn.active{background:var(--bg-hover);border-color:var(--text-secondary)}.contacts-view-toggle{display:flex;gap:0;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg-card)}.contacts-view-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s}.contacts-view-btn:hover,.contacts-view-btn.active{color:var(--text-primary);background:var(--bg-hover)}.contacts-view-btn svg{width:18px;height:18px}.contacts-filter-input,.contacts-filter-select{padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.assignee-select.contacts-filter-select{border:none;padding:0;background:transparent}.contacts-filter-input:focus,.contacts-filter-select:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.contacts-filter-select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-main)}.contacts-filter-input{flex:1;min-width:200px}.contacts-filter-select{min-width:150px}.contacts-add-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.contacts-add-btn:hover{opacity:.9}.contacts-bulk-edit-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.contacts-bulk-edit-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.contacts-clear-selection-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.contacts-clear-selection-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.contacts-merge-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.contacts-merge-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.contacts-add-btn--secondary{margin-top:.5rem}.contacts-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}.contacts-loading{margin:0;color:var(--text-secondary)}.contacts-empty{padding:2rem;text-align:center;background:var(--bg-card);border-radius:12px;border:1px dashed var(--border);color:var(--text-secondary)}.contacts-empty p{margin:0}.contacts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.contacts-card{position:relative;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:visible;display:flex;flex-direction:column}.contacts-card--selected{border-color:var(--focus-ring);box-shadow:0 0 0 1px var(--focus-ring)}.contacts-card-main{padding:1rem 1.25rem;flex:1;cursor:pointer;transition:background .15s;display:flex;flex-wrap:wrap;align-items:flex-start;gap:.5rem .75rem}.contacts-card-heading{flex:1;min-width:0;display:grid;grid-template-columns:auto 1fr;gap:.15rem .5rem;align-items:center}.contacts-card-heading .contacts-card-avatar{grid-row:1 / -1;align-self:center}.contacts-card-heading .contacts-card-name{margin:0;grid-column:2}.contacts-card-heading .contacts-card-meta,.contacts-card-heading .vip-badge{grid-column:2}.contacts-card-check{flex-shrink:0;cursor:pointer;display:flex;align-items:center;margin:0}.contacts-card-check input{width:1.1rem;height:1.1rem;cursor:pointer}.contacts-card-name{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.contacts-card-meta{margin:0;font-size:.875rem;color:var(--text-secondary)}.contacts-card-main:hover{background:var(--bg-hover)}.contacts-card-main:focus{outline:2px solid var(--focus-ring);outline-offset:-2px}.contacts-card-email,.contacts-card-phone{word-break:break-all}.contacts-card-sep{color:var(--border)}.contacts-card-country,.contacts-card-groups,.contacts-card-referral{margin:.35rem 0 0;font-size:.8rem;color:var(--text-secondary)}.contacts-card-assignee-wrap{position:absolute;top:-.5rem;right:.5rem;z-index:1}.contacts-card-assignee-wrap .contacts-card-assignee-avatar{box-shadow:0 0 0 2px var(--bg-card)}.contacts-card-actions{display:flex;gap:.5rem;padding:.5rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.contacts-card-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.contacts-card-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.contacts-card-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.supplier-form-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.supplier-form-modal{width:100%;max-width:36rem;max-height:90vh;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);overflow:hidden;display:flex;flex-direction:column}.supplier-form-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.supplier-form-header h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.supplier-form-close{padding:.25rem;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px;transition:color .15s,background .15s}.supplier-form-close:hover{color:var(--text-primary);background:var(--bg-hover)}.supplier-form-body{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.supplier-form-section{display:flex;flex-direction:column;gap:.6rem}.supplier-form-section-head{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.supplier-form-add-btn{font-size:.75rem;font-weight:500;color:var(--link);background:none;border:none;cursor:pointer;padding:.2rem .4rem;border-radius:4px}.supplier-form-add-btn:hover{text-decoration:underline}.supplier-form-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.supplier-form-label--full{width:100%}.supplier-form-input{padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s}.supplier-form-input:focus{border-color:var(--focus-ring)}.supplier-form-select{cursor:pointer;appearance:auto}.supplier-form-input--flex{flex:1;min-width:0}.supplier-form-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.supplier-form-check{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary);white-space:nowrap;cursor:pointer}.supplier-form-remove{padding:.2rem .4rem;font-size:.95rem;line-height:1;color:var(--text-secondary);background:var(--bg-hover);border:none;border-radius:4px;cursor:pointer}.supplier-form-remove:hover{color:var(--text-primary);background:var(--bg-active)}.supplier-form-address{border:1px solid var(--border);border-radius:8px;padding:.6rem .75rem;margin:0}.supplier-form-address-legend{font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;padding:0 .35rem}.supplier-form-address-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.4rem}.supplier-form-address-grid .supplier-form-label--full{grid-column:1 / -1}.supplier-form-message{padding:.6rem .75rem;font-size:.875rem;border-radius:8px}.supplier-form-message--error{background:var(--error-bg);color:var(--error-text)}.supplier-form-message--success{background:var(--success-bg);color:var(--success-text)}.supplier-form-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);flex-shrink:0}.supplier-form-cancel{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.supplier-form-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.supplier-form-submit{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.supplier-form-submit:hover:not(:disabled){opacity:.9}.supplier-form-submit:disabled{opacity:.7;cursor:not-allowed}.merge-supplier-modal{width:100%;max-width:28rem;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal, 0 20px 40px rgba(0, 0, 0, .15));padding:1.25rem}.merge-supplier-modal .modal-title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.merge-supplier-desc{margin:0 0 1.25rem;font-size:.9rem;color:var(--text-secondary);line-height:1.45}.merge-supplier-list{margin:0 0 1rem;padding:0;border:none}.merge-supplier-legend{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;display:block}.merge-supplier-option{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;margin-bottom:.35rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.merge-supplier-option:hover{background:var(--bg-hover)}.merge-supplier-option:has(input:checked){border-color:var(--focus-ring);background:var(--focus-ring-subtle, rgba(13, 110, 253, .08))}.merge-supplier-option input{flex-shrink:0}.merge-supplier-name{font-weight:600;color:var(--text-primary)}.merge-supplier-meta{font-size:.85rem;color:var(--text-secondary);margin-left:auto}.merge-supplier-error{margin:0 0 1rem;padding:.5rem .75rem;font-size:.875rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.merge-supplier-modal .modal-actions{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.merge-supplier-modal .modal-btn{padding:.5rem 1rem;font-size:.9rem;border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.merge-supplier-modal .modal-btn--secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.merge-supplier-modal .modal-btn--secondary:hover{background:var(--bg-hover)}.merge-supplier-modal .modal-btn--primary{background:var(--btn-primary);color:#fff;border:none;font-weight:500}.merge-supplier-modal .modal-btn--primary:hover:not(:disabled){opacity:.9}.merge-supplier-modal .modal-btn--primary:disabled{opacity:.7;cursor:not-allowed}.bulk-edit-supplier-modal{width:100%;max-width:28rem;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal, 0 20px 40px rgba(0, 0, 0, .15));padding:1.25rem}.bulk-edit-supplier-modal .modal-title{margin:0 0 .5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.bulk-edit-supplier-desc{margin:0 0 1.25rem;font-size:.9rem;color:var(--text-secondary);line-height:1.45}.bulk-edit-supplier-field{margin-bottom:1rem}.bulk-edit-supplier-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;margin-bottom:.2rem}.bulk-edit-supplier-select{width:100%;padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-page);color:var(--text-primary)}.bulk-edit-supplier-select:focus{outline:none;border-color:var(--focus-ring)}.bulk-edit-supplier-error{margin:0 0 1rem;padding:.5rem .75rem;font-size:.875rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.bulk-edit-supplier-modal .modal-actions{display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap}.bulk-edit-supplier-modal .modal-btn{padding:.5rem 1rem;font-size:.9rem;border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.bulk-edit-supplier-modal .modal-btn--secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.bulk-edit-supplier-modal .modal-btn--secondary:hover{background:var(--bg-hover)}.bulk-edit-supplier-modal .modal-btn--primary{background:var(--btn-primary);color:#fff;border:none;font-weight:500}.bulk-edit-supplier-modal .modal-btn--primary:hover:not(:disabled){opacity:.9}.bulk-edit-supplier-modal .modal-btn--primary:disabled{opacity:.7;cursor:not-allowed}.suppliers-table-wrap{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden}.suppliers-table-toolbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-main)}.suppliers-table-page-size{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.suppliers-table-page-size select{padding:.35rem .5rem;font-size:.875rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);cursor:pointer}.suppliers-table-count{font-size:.875rem;color:var(--text-secondary)}.suppliers-table-scroll{overflow-x:auto}.suppliers-table{width:100%;border-collapse:collapse;font-size:.9rem}.suppliers-table-th,.suppliers-table-td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.suppliers-table-th{background:var(--bg-main);font-weight:600;color:var(--text-primary);white-space:nowrap}.suppliers-table-th--checkbox{width:2.5rem;min-width:2.5rem;padding:.5rem}.suppliers-table-check-all,.suppliers-table-check{display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0}.suppliers-table-check-all input,.suppliers-table-check input{width:1rem;height:1rem;cursor:pointer}.suppliers-table-td--checkbox{width:2.5rem;min-width:2.5rem;padding:.5rem;vertical-align:middle}.suppliers-table-th--thumb{width:64px;min-width:64px}.suppliers-table-th-content{display:flex;flex-direction:column;gap:.35rem}.suppliers-table-th-label{display:block}.suppliers-table-sort{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem 0;font:inherit;font-weight:600;color:var(--text-primary);background:none;border:none;cursor:pointer;text-align:left;transition:color .15s}.suppliers-table-sort:hover,.suppliers-table-sort.active{color:var(--focus-ring)}.suppliers-table-sort-icon{font-size:.75em;opacity:.9}.suppliers-table-filter-input,.suppliers-table-filter-select{padding:.35rem .5rem;font-size:.8rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);width:100%;max-width:140px}.suppliers-table-filter-input:focus,.suppliers-table-filter-select:focus{outline:none;border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.suppliers-table-assignee-select{max-width:140px}.suppliers-table-th--extra{font-weight:600}.suppliers-table-th--actions{width:1%;white-space:nowrap}.suppliers-table-row{cursor:pointer;transition:background .15s}.suppliers-table-row:hover{background:var(--bg-hover)}.suppliers-table-row:focus{outline:none}.suppliers-table-row:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-2px}.suppliers-table-td--thumb{width:64px;min-width:64px;padding:.4rem}.suppliers-table-avatar{width:48px;height:48px;border-radius:50%}.suppliers-table-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;color:var(--text-secondary)}.suppliers-table-td--updated{white-space:nowrap;color:var(--text-secondary);font-size:.85rem}.suppliers-table-td--actions{white-space:nowrap}.suppliers-table-actions{display:flex;gap:.35rem;flex-wrap:wrap}.suppliers-table-btn{padding:.3rem .6rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.suppliers-table-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.suppliers-table-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.suppliers-table-loading,.suppliers-table-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.suppliers-table-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.suppliers-table-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.suppliers-table-pagination-btn{padding:.4rem .75rem;font-size:.875rem;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s}.suppliers-table-pagination-btn:hover:not(:disabled){background:var(--bg-hover)}.suppliers-table-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.suppliers-table-pagination-info{font-size:.875rem;color:var(--text-secondary)}.suppliers-content{padding:1.5rem}.suppliers-filter-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.suppliers-filter-btn svg{width:18px;height:18px}.suppliers-filter-btn:hover{background:var(--bg-hover)}.suppliers-filter-btn.active{background:var(--bg-hover);border-color:var(--text-secondary)}.suppliers-view-toggle{display:flex;gap:0;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg-card)}.suppliers-view-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s}.suppliers-view-btn:hover,.suppliers-view-btn.active{color:var(--text-primary);background:var(--bg-hover)}.suppliers-view-btn svg{width:18px;height:18px}.suppliers-filter-input,.suppliers-filter-select{padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.assignee-select.suppliers-filter-select{border:none;padding:0;background:transparent}.suppliers-filter-input:focus,.suppliers-filter-select:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.suppliers-filter-select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-main)}.suppliers-filter-input{flex:1;min-width:200px}.suppliers-filter-select{min-width:150px}.suppliers-add-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.suppliers-add-btn:hover{opacity:.9}.suppliers-bulk-edit-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.suppliers-bulk-edit-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.suppliers-clear-selection-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.suppliers-clear-selection-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.suppliers-merge-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.suppliers-merge-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.suppliers-add-btn--secondary{margin-top:.5rem}.suppliers-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}.suppliers-loading{margin:0;color:var(--text-secondary)}.suppliers-empty{padding:2rem;text-align:center;background:var(--bg-card);border-radius:12px;border:1px dashed var(--border);color:var(--text-secondary)}.suppliers-empty p{margin:0}.suppliers-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.suppliers-card{position:relative;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:visible;display:flex;flex-direction:column}.suppliers-card--selected{border-color:var(--focus-ring);box-shadow:0 0 0 1px var(--focus-ring)}.suppliers-card-main{padding:1rem 1.25rem;flex:1;cursor:pointer;transition:background .15s;display:flex;flex-wrap:wrap;align-items:flex-start;gap:.5rem .75rem}.suppliers-card-check{flex-shrink:0;cursor:pointer;display:flex;align-items:center;margin:0}.suppliers-card-check input{width:1.1rem;height:1.1rem;cursor:pointer}.suppliers-card-name{flex:1;min-width:0;margin:0 0 .35rem;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.suppliers-card-meta{width:100%;margin:0;font-size:.875rem;color:var(--text-secondary)}.suppliers-card-main:hover{background:var(--bg-hover)}.suppliers-card-main:focus{outline:2px solid var(--focus-ring);outline-offset:-2px}.suppliers-card-email,.suppliers-card-phone{word-break:break-all}.suppliers-card-sep{color:var(--border)}.suppliers-card-country{margin:.35rem 0 0;font-size:.8rem;color:var(--text-secondary)}.suppliers-card-assignee-wrap{position:absolute;top:-.5rem;right:.5rem;z-index:1}.suppliers-card-assignee-wrap .suppliers-card-assignee-avatar{box-shadow:0 0 0 2px var(--bg-card)}.suppliers-card-actions{display:flex;gap:.5rem;padding:.5rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.suppliers-card-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.suppliers-card-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.suppliers-card-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.inbox-modal-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.inbox-modal{background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);max-width:440px;width:100%;max-height:90vh;overflow-y:auto}.inbox-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.inbox-modal-header h2{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.inbox-modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;transition:color .15s,background .15s}.inbox-modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.inbox-modal-body{padding:1.25rem}.inbox-modal-desc{margin:0 0 1rem;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.inbox-modal-identifier{margin:0 0 1rem;font-size:.95rem;font-weight:500;color:var(--text-primary);word-break:break-all}.inbox-modal-input{width:100%;padding:.6rem .75rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);margin-bottom:1rem}.inbox-modal-input:focus{outline:none;border-color:var(--focus-ring)}.inbox-modal-select-wrap{margin-bottom:1rem}.inbox-modal-select-wrap label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.35rem}.inbox-modal-select{width:100%;padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary)}.inbox-modal-channel-wrap{margin-bottom:1rem}.inbox-modal-channel-wrap>label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.35rem}.inbox-modal-channel-options{display:flex;flex-direction:column;gap:.5rem}.inbox-modal-radio{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer}.inbox-modal-radio input{width:1rem;height:1rem}.inbox-modal-error{margin:0 0 .75rem;font-size:.875rem;color:var(--error-text)}.inbox-modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.inbox-modal-actions-inline{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.inbox-modal-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s;font-family:inherit}.inbox-modal-btn--secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.inbox-modal-btn--secondary:hover{background:var(--bg-active)}.inbox-modal-btn--primary{background:var(--btn-primary);color:#fff;border:none}.inbox-modal-btn--primary:hover:not(:disabled){opacity:.9}.inbox-modal-btn:disabled{opacity:.7;cursor:not-allowed}.integrations-content{padding:1.5rem}.integrations-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.integrations-tab{padding:.6rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .15s,border-color .15s}.integrations-tab:hover{color:var(--text-primary)}.integrations-tab--active{color:var(--text-primary);border-bottom-color:var(--btn-primary)}.integrations-tabpanel{outline:none}.integrations-banner{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.integrations-banner--success{background:var(--success-bg);color:var(--success-text)}.integrations-banner--error{background:var(--error-bg);color:var(--error-text)}.integrations-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}.integrations-section{max-width:640px}.integrations-section-title{margin:0 0 .25rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.integrations-section-desc{margin:0 0 1.5rem;font-size:.95rem;color:var(--text-secondary);line-height:1.5}.integrations-connect-panel{padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;box-shadow:var(--shadow-card)}.integrations-panel-title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.integrations-steps{margin:0 0 1rem;padding-left:1.25rem;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.integrations-steps li{margin-bottom:.35rem}.integrations-connect-panel code{font-size:.85em;padding:.15em .4em;background:var(--bg-hover);border-radius:4px;font-family:ui-monospace,monospace}.integrations-connect-panel a{color:var(--btn-primary);text-decoration:none}.integrations-connect-panel a:hover{text-decoration:underline}.integrations-inline-error{margin:0 0 .75rem;font-size:.875rem;color:var(--error-text)}.integrations-connect-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.integrations-connect-btn:hover:not(:disabled){opacity:.9}.integrations-connect-btn:disabled{opacity:.7;cursor:not-allowed}.integrations-list-wrap{padding:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-card)}.integrations-loading,.integrations-empty{margin:0;font-size:.9rem;color:var(--text-secondary)}.integrations-list{margin:0;padding:0;list-style:none}.integrations-list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.integrations-list-item:last-child{border-bottom:none}.integrations-list-label{font-weight:500;color:var(--text-primary)}.integrations-list-email{font-size:.875rem;color:var(--text-secondary)}.integrations-list-actions{margin-left:auto;display:flex;align-items:center;gap:.5rem}.integrations-reconnect-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.integrations-reconnect-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.integrations-reconnect-btn:disabled{opacity:.7;cursor:not-allowed}.integrations-disconnect-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--error-text);background:none;border:1px solid var(--error-text);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.integrations-disconnect-btn:hover{background:var(--error-bg)}.projects-page{display:flex;flex-direction:column;min-height:0}.projects-content{padding:1.5rem;overflow:auto}.projects-workspace-select,.projects-search-input{padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.projects-workspace-select:focus,.projects-search-input:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.projects-workspace-select{min-width:180px}.projects-search-input{flex:1;min-width:200px}.projects-external-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;text-decoration:none;transition:opacity .15s,background .15s}.projects-external-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.projects-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.projects-retry-btn{padding:.35rem .75rem;font-size:.85rem;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;cursor:pointer}.projects-retry-btn:hover{background:var(--bg-hover)}.projects-loading,.projects-loading-more{margin:0;color:var(--text-secondary)}.projects-empty{padding:2rem;text-align:center;background:var(--bg-card);border-radius:12px;border:1px dashed var(--border);color:var(--text-secondary)}.projects-empty p{margin:0}.projects-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border);background:var(--bg-card);margin-bottom:1rem}.projects-table{width:100%;border-collapse:collapse;font-size:.9rem}.projects-table th,.projects-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.projects-table th{font-weight:600;color:var(--text-secondary);background:var(--bg-main);white-space:nowrap}.projects-table tbody tr:last-child td{border-bottom:none}.projects-table tbody tr:hover{background:var(--bg-hover)}.projects-cell-name{max-width:280px}.projects-task-name{font-weight:500;color:var(--text-primary)}.projects-cell-projects{max-width:200px;color:var(--text-secondary)}.projects-status-done{color:var(--text-secondary)}.projects-status-todo{color:var(--text-primary)}.projects-link{color:var(--btn-primary);text-decoration:none}.projects-link:hover{text-decoration:underline}.projects-load-more{margin-bottom:1rem}.projects-load-more-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--btn-primary);background:var(--bg-card);border:1px solid var(--btn-primary);border-radius:8px;cursor:pointer;transition:opacity .15s,background .15s}.projects-load-more-btn:hover{opacity:.9;background:var(--focus-ring-subtle, rgba(13, 110, 253, .1))}.projects-filter-hint{margin:0;font-size:.85rem;color:var(--text-secondary)}.raw-material-form-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.raw-material-form-modal{width:100%;max-width:36rem;max-height:90vh;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);overflow:hidden;display:flex;flex-direction:column}.raw-material-form-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.raw-material-form-header h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.raw-material-form-close{padding:.25rem;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px;transition:color .15s,background .15s}.raw-material-form-close:hover{color:var(--text-primary);background:var(--bg-hover)}.raw-material-form-body{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.raw-material-form-section{display:flex;flex-direction:column;gap:.6rem}.raw-material-form-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.raw-material-form-label--full{width:100%}.raw-material-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.raw-material-form-input{padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s}.raw-material-form-input:focus{border-color:var(--focus-ring)}.raw-material-form-select{cursor:pointer;appearance:auto}.raw-material-form-textarea{resize:vertical;min-height:3.5rem;padding:.5rem .65rem;font-size:.95rem}.raw-material-form-image-section{display:flex;flex-direction:column;gap:.5rem}.raw-material-form-image-section .raw-material-form-label{margin:0}.raw-material-form-image-zone{min-height:120px;border:1px dashed var(--border);border-radius:8px;background:var(--bg-main);display:flex;align-items:center;justify-content:center;overflow:hidden}.raw-material-form-image-zone--dragover{border-color:var(--focus-ring);background:var(--focus-ring-subtle, rgba(59, 130, 246, .08))}.raw-material-form-image-preview{position:relative;width:100%;height:100%;min-height:120px}.raw-material-form-image-preview img{width:100%;height:160px;object-fit:cover;display:block}.raw-material-form-image-remove{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;padding:0;font-size:1.25rem;line-height:1;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.raw-material-form-image-remove:hover{background:var(--error-bg);color:var(--error-text)}.raw-material-form-image-upload{padding:1.5rem;cursor:pointer;display:block;text-align:center}.raw-material-form-image-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.raw-material-form-image-upload-text{font-size:.9rem;color:var(--text-secondary)}.raw-material-form-image-upload:hover .raw-material-form-image-upload-text{color:var(--text-primary)}.raw-material-form-message{padding:.6rem .75rem;font-size:.875rem;border-radius:8px}.raw-material-form-message--error{background:var(--error-bg);color:var(--error-text)}.raw-material-form-message--success{background:var(--success-bg);color:var(--success-text)}.raw-material-form-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);flex-shrink:0}.raw-material-form-cancel{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.raw-material-form-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.raw-material-form-submit{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.raw-material-form-submit:hover:not(:disabled){opacity:.9}.raw-material-form-submit:disabled{opacity:.7;cursor:not-allowed}.raw-materials-table-wrap{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden}.raw-materials-table-toolbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-main)}.raw-materials-table-page-size{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.raw-materials-table-page-size select{padding:.35rem .5rem;font-size:.875rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);cursor:pointer}.raw-materials-table-count{font-size:.875rem;color:var(--text-secondary)}.raw-materials-table-scroll{overflow-x:auto}.raw-materials-table{width:100%;border-collapse:collapse;font-size:.9rem}.raw-materials-table-th,.raw-materials-table-td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.raw-materials-table-th{background:var(--bg-main);font-weight:600;color:var(--text-primary);white-space:nowrap}.raw-materials-table-th--thumb{width:64px;min-width:64px}.raw-materials-table-th-content{display:flex;flex-direction:column;gap:.35rem}.raw-materials-table-th-label{display:block}.raw-materials-table-sort{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem 0;font:inherit;font-weight:600;color:var(--text-primary);background:none;border:none;cursor:pointer;text-align:left;transition:color .15s}.raw-materials-table-sort:hover,.raw-materials-table-sort.active{color:var(--focus-ring)}.raw-materials-table-sort-icon{font-size:.75em;opacity:.9}.raw-materials-table-filter-input,.raw-materials-table-filter-select{padding:.35rem .5rem;font-size:.8rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-primary);width:100%;max-width:140px}.raw-materials-table-filter-input:focus,.raw-materials-table-filter-select:focus{outline:none;border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.raw-materials-table-th--actions{width:1%;white-space:nowrap}.raw-materials-table-row{cursor:pointer;transition:background .15s}.raw-materials-table-row:hover{background:var(--bg-hover)}.raw-materials-table-row:focus{outline:none}.raw-materials-table-row:focus-visible{outline:2px solid var(--focus-ring);outline-offset:-2px}.raw-materials-table-td--thumb{width:64px;min-width:64px;padding:.4rem}.raw-materials-table-thumb{width:48px;height:48px;border-radius:8px;background:var(--raw-materials-card-cover-placeholder, #e5e7eb);background-size:cover;background-position:center;flex-shrink:0}.raw-materials-table-td--num{white-space:nowrap}.raw-materials-table-td--notes{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.raw-materials-table-td--updated{white-space:nowrap;color:var(--text-secondary);font-size:.85rem}.raw-materials-table-td--actions{white-space:nowrap}.raw-materials-table-actions{display:flex;gap:.35rem;flex-wrap:wrap}.raw-materials-table-btn{padding:.3rem .6rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.raw-materials-table-btn:hover,.raw-materials-table-btn--archive:hover{background:var(--bg-hover);color:var(--text-primary)}.raw-materials-table-btn--restore:hover{background:var(--success-bg, rgba(34, 197, 94, .1));color:var(--success-text, #16a34a);border-color:var(--success-text, #16a34a)}.raw-materials-table-loading,.raw-materials-table-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.raw-materials-table-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.raw-materials-table-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.raw-materials-table-pagination-btn{padding:.4rem .75rem;font-size:.875rem;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s}.raw-materials-table-pagination-btn:hover:not(:disabled){background:var(--bg-hover)}.raw-materials-table-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.raw-materials-table-pagination-info{font-size:.875rem;color:var(--text-secondary)}.raw-materials-content{padding:1.5rem}.raw-materials-status-toggle{display:flex;gap:0;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg-card)}.raw-materials-status-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s}.raw-materials-status-btn:hover,.raw-materials-status-btn.active{color:var(--text-primary);background:var(--bg-hover)}.raw-materials-filter-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.raw-materials-filter-btn svg{width:18px;height:18px}.raw-materials-filter-btn:hover{background:var(--bg-hover)}.raw-materials-filter-btn.active{background:var(--bg-hover);border-color:var(--text-secondary)}.raw-materials-view-toggle{display:flex;gap:0;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg-card)}.raw-materials-view-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s}.raw-materials-view-btn:hover,.raw-materials-view-btn.active{color:var(--text-primary);background:var(--bg-hover)}.raw-materials-view-btn svg{width:18px;height:18px}.raw-materials-filter-input,.raw-materials-filter-select{padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.raw-materials-filter-input:focus,.raw-materials-filter-select:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.raw-materials-filter-input{flex:1;min-width:200px}.raw-materials-filter-select{min-width:150px}.raw-materials-add-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.raw-materials-add-btn:hover{opacity:.9}.raw-materials-add-btn--secondary{margin-top:.5rem}.raw-materials-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}.raw-materials-loading{margin:0;color:var(--text-secondary)}.raw-materials-empty{padding:2rem;text-align:center;background:var(--bg-card);border-radius:12px;border:1px dashed var(--border);color:var(--text-secondary)}.raw-materials-empty p{margin:0}.raw-materials-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.raw-materials-card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden;display:flex;flex-direction:column}.raw-materials-card-cover{height:140px;flex-shrink:0;background:var(--raw-materials-card-cover-placeholder, #e5e7eb);background-size:cover;background-position:center}.raw-materials-card-clickable{flex:1;display:flex;flex-direction:column;cursor:pointer;outline:none}.raw-materials-card-clickable:hover .raw-materials-card-main{background:var(--bg-hover)}.raw-materials-card-clickable:focus{outline:2px solid var(--focus-ring);outline-offset:-2px}.raw-materials-card-main{padding:1rem 1.25rem;flex:1;transition:background .15s;display:flex;flex-direction:column;gap:.35rem}.raw-materials-card-main:focus{outline:none}.raw-materials-card-name{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.raw-materials-card-meta{margin:0;font-size:.875rem;color:var(--text-secondary)}.raw-materials-card-category{text-transform:capitalize}.raw-materials-card-sep{color:var(--border)}.raw-materials-card-colour{font-style:italic}.raw-materials-card-quantity{margin:0;font-size:.85rem;color:var(--text-secondary)}.raw-materials-card-notes{margin:.35rem 0 0;font-size:.8rem;color:var(--text-secondary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.raw-materials-card-actions{display:flex;gap:.5rem;padding:.5rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.raw-materials-card-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.raw-materials-card-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.raw-materials-card-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.raw-materials-card-btn--archive:hover{background:var(--bg-hover);color:var(--text-primary)}.raw-materials-card-btn--restore:hover{background:var(--success-bg, rgba(34, 197, 94, .1));color:var(--success-text, #16a34a);border-color:var(--success-text, #16a34a)}.contact-groups-table .contacts-table-td--description{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-groups-page{display:flex;flex-direction:column;min-height:0;flex:1}.contact-groups-card-heading{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.contact-groups-card-description{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vip-badge{display:inline-block;margin-top:.25rem;padding:.15rem .4rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-primary);background:var(--bg-hover, rgba(0, 0, 0, .06));border:1px solid var(--border);border-radius:4px}.fp-multiselect{width:100%}.fp-multiselect-empty{margin:.35rem 0 0;font-size:.85rem;color:var(--text-secondary)}.fp-multiselect-trigger{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;text-align:left;font-size:.95rem;cursor:pointer}.fp-multiselect-trigger:disabled{cursor:not-allowed;opacity:.85}.fp-multiselect-trigger-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fp-multiselect-chevron{flex-shrink:0;font-size:.65rem;color:var(--text-secondary);line-height:1}.fp-multiselect-panel{overflow-y:auto;padding:.35rem 0;margin:0;list-style:none;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-modal, 0 8px 24px rgba(0, 0, 0, .12))}.fp-multiselect-panel--portal{box-sizing:border-box}.fp-multiselect-option{display:flex;align-items:center;gap:.5rem;padding:.45rem .65rem;font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:background .12s}.fp-multiselect-option:hover{background:var(--bg-hover)}.fp-multiselect-option input{margin:0;flex-shrink:0}.fp-multiselect-option span{min-width:0}.fp-form-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.fp-form-modal{width:100%;max-width:36rem;max-height:90vh;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-modal);overflow:hidden;display:flex;flex-direction:column}.fp-form-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.fp-form-header h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.fp-form-close{padding:.25rem;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px;transition:color .15s,background .15s}.fp-form-close:hover{color:var(--text-primary);background:var(--bg-hover)}.fp-form-body{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.fp-form-section{display:flex;flex-direction:column;gap:.6rem}.fp-form-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.fp-form-label--full{width:100%}.fp-form-input{padding:.5rem .65rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-input);color:var(--text-primary);outline:none;transition:border-color .15s}.fp-form-input:focus{border-color:var(--focus-ring)}.fp-form-select{cursor:pointer;appearance:auto}.fp-form-hint{display:block;margin-top:.35rem;font-size:.75rem;font-weight:400;color:var(--text-secondary);letter-spacing:normal}.fp-form-textarea{resize:vertical;min-height:3.5rem;padding:.5rem .65rem;font-size:.95rem}.fp-form-tags-wrap{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem;padding:.5rem 0}.fp-form-tags-empty{margin:0;font-size:.85rem;color:var(--text-secondary)}.fp-form-tag-check{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;font-size:.85rem;color:var(--text-secondary);background:var(--bg-hover);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.fp-form-tag-check:hover{color:var(--text-primary)}.fp-form-tag-check input{margin:0}.fp-form-image-section{display:flex;flex-direction:column;gap:.5rem}.fp-form-image-section .fp-form-label{margin:0}.fp-form-image-zone{min-height:120px;border:1px dashed var(--border);border-radius:8px;background:var(--bg-main);display:flex;align-items:center;justify-content:center;overflow:hidden}.fp-form-image-zone--dragover{border-color:var(--focus-ring);background:var(--focus-ring-subtle, rgba(59, 130, 246, .08))}.fp-form-image-preview{position:relative;width:100%;height:100%;min-height:120px}.fp-form-image-preview img{width:100%;height:160px;object-fit:cover;display:block}.fp-form-image-remove{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;padding:0;font-size:1.25rem;line-height:1;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.fp-form-image-remove:hover{background:var(--error-bg);color:var(--error-text)}.fp-form-image-upload{padding:1.5rem;cursor:pointer;display:block;text-align:center}.fp-form-image-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.fp-form-image-upload-text{font-size:.9rem;color:var(--text-secondary)}.fp-form-image-upload:hover .fp-form-image-upload-text{color:var(--text-primary)}.fp-form-message{padding:.6rem .75rem;font-size:.875rem;border-radius:8px}.fp-form-message--error{background:var(--error-bg);color:var(--error-text)}.fp-form-message--success{background:var(--success-bg);color:var(--success-text)}.fp-form-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);flex-shrink:0}.fp-form-cancel{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.fp-form-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.fp-form-submit{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.fp-form-submit:hover:not(:disabled){opacity:.9}.fp-form-submit:disabled{opacity:.7;cursor:not-allowed}.finished-products-content{padding:1.5rem}.fp-status-toggle{display:flex;gap:0;border-radius:8px;border:1px solid var(--border);overflow:hidden;background:var(--bg-card)}.fp-status-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background .15s,color .15s}.fp-status-btn:hover,.fp-status-btn.active{color:var(--text-primary);background:var(--bg-hover)}.fp-filter-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.fp-filter-btn svg{width:18px;height:18px}.fp-filter-btn:hover{background:var(--bg-hover)}.fp-filter-btn.active{background:var(--bg-hover);border-color:var(--text-secondary)}.fp-filter-input{padding:.5rem .75rem;font-size:.9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);outline:none;min-width:200px}.fp-filter-input:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.fp-add-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.fp-add-btn:hover{opacity:.9}.fp-add-btn--secondary{margin-top:.5rem}.fp-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}.fp-loading{margin:0;color:var(--text-secondary)}.fp-empty{padding:2rem;text-align:center;background:var(--bg-card);border-radius:12px;border:1px dashed var(--border);color:var(--text-secondary)}.fp-empty p{margin:0}.fp-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.fp-card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden;display:flex;flex-direction:column}.fp-card-cover{height:140px;flex-shrink:0;background:var(--raw-materials-card-cover-placeholder, #e5e7eb);background-size:cover;background-position:center}.fp-card-clickable{flex:1;display:flex;flex-direction:column;cursor:pointer;outline:none}.fp-card-clickable:hover .fp-card-main{background:var(--bg-hover)}.fp-card-clickable:focus{outline:2px solid var(--focus-ring);outline-offset:-2px}.fp-card-main{padding:1rem 1.25rem;flex:1;transition:background .15s;display:flex;flex-direction:column;gap:.35rem}.fp-card-name{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.fp-card-meta{margin:0;font-size:.875rem;color:var(--text-secondary)}.fp-card-notes{margin:.35rem 0 0;font-size:.8rem;color:var(--text-secondary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fp-card-actions{display:flex;gap:.5rem;padding:.5rem 1rem;border-top:1px solid var(--border);background:var(--bg-main)}.fp-card-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.fp-card-btn:hover,.fp-card-btn--archive:hover{background:var(--bg-hover);color:var(--text-primary)}.fp-card-btn--restore:hover{background:var(--success-bg, rgba(34, 197, 94, .1));color:var(--success-text, #16a34a);border-color:var(--success-text, #16a34a)}.config-option-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.config-option-modal{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-card);width:100%;max-width:400px}.config-option-modal--wide{max-width:440px}.config-option-colour-row{display:flex;align-items:center;gap:.75rem;margin-top:.35rem}.config-option-colour-picker{width:48px;height:36px;padding:2px;border:1px solid var(--border);border-radius:8px;background:var(--bg-main);cursor:pointer}.config-option-colour-hex{flex:1;font-family:ui-monospace,monospace}.config-option-image-zone{min-height:100px;margin-top:.35rem;border:1px dashed var(--border);border-radius:8px;background:var(--bg-main);display:flex;align-items:center;justify-content:center;overflow:hidden}.config-option-image-zone--dragover{border-color:var(--focus-ring);background:var(--focus-ring-subtle, rgba(59, 130, 246, .08))}.config-option-image-preview{position:relative;width:100%;min-height:100px}.config-option-image-preview img{width:100%;height:140px;object-fit:cover;display:block}.config-option-image-remove{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;padding:0;font-size:1.25rem;line-height:1;color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.config-option-image-remove:hover{background:var(--error-bg);color:var(--error-text)}.config-option-image-empty{padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem}.config-option-image-restore{padding:.35rem .75rem;font-size:.85rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.config-option-image-restore:hover{background:var(--bg-hover);color:var(--text-primary)}.config-option-image-upload{padding:1.5rem;cursor:pointer;display:block;text-align:center}.config-option-image-upload span{font-size:.9rem;color:var(--text-secondary)}.config-option-image-upload:hover span{color:var(--text-primary)}.config-option-image-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.config-option-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.config-option-header h2{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.config-option-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;font-size:1.5rem;line-height:1;color:var(--text-secondary);background:none;border:none;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.config-option-close:hover{background:var(--bg-hover);color:var(--text-primary)}.config-option-body{padding:1.25rem}.config-option-label{display:block;margin-bottom:1rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.config-option-input{display:block;width:100%;margin-top:.35rem;padding:.5rem .75rem;font-size:.95rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-main);color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.config-option-input:focus{border-color:var(--focus-ring);box-shadow:0 0 0 2px var(--focus-ring-subtle)}.config-option-message{margin-bottom:1rem;padding:.5rem .75rem;font-size:.875rem;border-radius:8px}.config-option-message--error{background:var(--error-bg);color:var(--error-text)}.config-option-message--success{background:var(--success-bg);color:var(--success-text)}.config-option-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.config-option-cancel{padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.config-option-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.config-option-submit{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.config-option-submit:hover:not(:disabled){opacity:.9}.config-option-submit:disabled{opacity:.7;cursor:not-allowed}.config-tab-toolbar{margin-bottom:1rem}.config-tab-add-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.config-tab-add-btn:hover{opacity:.9}.config-tab-add-btn--secondary{margin-top:.5rem}.config-tab-loading{margin:0;color:var(--text-secondary)}.config-tab-empty{padding:2rem;text-align:center;background:var(--bg-card);border-radius:12px;border:1px dashed var(--border);color:var(--text-secondary)}.config-tab-empty p{margin:0}.config-tab-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px}.config-tab-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-card)}.config-tab-table{width:100%;border-collapse:collapse}.config-tab-th,.config-tab-td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.config-tab-th{font-weight:600;color:var(--text-secondary);font-size:.85rem}.config-tab-th--preview{width:56px;padding:.5rem}.config-tab-td--preview{width:56px;padding:.5rem;vertical-align:middle}.config-tab-preview{width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background-size:cover;background-position:center}.config-tab-preview--empty{background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-secondary)}.config-tab-th--actions,.config-tab-td--actions{width:140px}.config-tab-table tbody tr:last-child td{border-bottom:none}.config-tab-row:hover{background:var(--bg-hover)}.config-tab-actions{display:flex;gap:.5rem}.config-tab-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.config-tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.config-tab-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.configuration-content{padding:1.5rem}.configuration-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.configuration-tab{padding:.6rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .15s,border-color .15s}.configuration-tab:hover{color:var(--text-primary)}.configuration-tab--active{color:var(--text-primary);border-bottom-color:var(--btn-primary)}.configuration-tabpanel{outline:none}.configuration-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.configuration-add-btn{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:var(--btn-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s}.configuration-add-btn:hover{opacity:.9}.configuration-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-card)}.configuration-table{width:100%;border-collapse:collapse}.configuration-table th,.configuration-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.configuration-table th{font-weight:600;color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:.02em}.configuration-table td{color:var(--text-primary)}.configuration-table tbody tr:last-child td{border-bottom:none}.configuration-table tbody tr:hover{background:var(--bg-hover)}.configuration-table-actions{display:flex;gap:.5rem}.configuration-table-btn{padding:.35rem .75rem;font-size:.8rem;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.configuration-table-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.configuration-table-btn--danger:hover{background:var(--error-bg);color:var(--error-text);border-color:var(--error-text)}.configuration-loading,.configuration-empty{padding:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.configuration-error{padding:.75rem 1rem;background:var(--error-bg);color:var(--error-text);border-radius:8px;margin-bottom:1rem}
