.logo-company[data-v-ed0e04eb]{font-size:13px;font-weight:700;color:var(--color-text-primary);letter-spacing:.02em}.nav-item[data-v-ed0e04eb]{text-decoration:none}.nav-user[data-v-ed0e04eb]{margin-left:auto;display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--color-text-secondary)}.nav-datetime[data-v-ed0e04eb]{font-size:12px;color:var(--color-text-tertiary);margin-right:8px}.nav-user-avatar[data-v-ed0e04eb]{width:28px;height:28px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.nav-user-name[data-v-ed0e04eb]{font-weight:600;color:var(--color-text-primary)}.nav-user-role[data-v-ed0e04eb]{font-size:11px;padding:2px 7px;border-radius:10px;font-weight:600}.nav-impersonate[data-v-ed0e04eb]{font-size:12px;padding:3px 8px;border:1.5px solid #f0a030;border-radius:6px;background:#fffbf0;color:#9a6a00;cursor:pointer;font-weight:600}.nav-logout[data-v-ed0e04eb]{margin-left:8px;padding:4px 12px;font-size:12px;border:1px solid var(--color-border);border-radius:6px;background:transparent;color:var(--color-text-secondary);cursor:pointer}.impersonate-banner[data-v-ed0e04eb]{display:flex;align-items:center;justify-content:center;gap:8px;background:#fff3cd;border-bottom:2px solid #f0a030;color:#92400e;font-size:13px;font-weight:600;padding:6px 16px;position:sticky;top:52px;z-index:199}.impersonate-banner button[data-v-ed0e04eb]{padding:2px 10px;font-size:11px;border:1px solid #92400e;border-radius:4px;background:#92400e;color:#fff;cursor:pointer;font-weight:600}.auth-system-name[data-v-c315f3e6]{text-align:center;margin:-8px 0 16px;font-size:14px;font-weight:600;color:var(--color-text-secondary);letter-spacing:.05em}.auth-turnstile[data-v-c315f3e6]{margin:12px 0;display:flex;justify-content:center}.auth-mobile-block[data-v-c315f3e6]{text-align:center;padding:8px 0 4px}.auth-mobile-icon[data-v-c315f3e6]{font-size:48px;margin-bottom:16px}.auth-mobile-title[data-v-c315f3e6]{font-size:16px;font-weight:700;color:var(--color-text-primary);margin-bottom:10px}.auth-mobile-desc[data-v-c315f3e6]{font-size:13px;color:var(--color-text-secondary);line-height:1.8}.auth-hint[data-v-c315f3e6]{font-size:12px;color:#9aab97;text-align:center;margin-top:14px;line-height:1.7}.sp-section[data-v-bc6403dd]{font-size:12px;font-weight:700;margin:0;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.sp-label[data-v-bc6403dd]{color:var(--color-text-tertiary);font-size:13px;display:block;margin-bottom:1px}.sp-edit[data-v-bc6403dd]{padding:2px 10px;font-size:12px;background:#fff;color:var(--color-primary);border:1.5px solid var(--color-primary);border-radius:5px}.sp-add[data-v-bc6403dd]{padding:2px 10px;font-size:12px;background:var(--color-success);color:#fff;border:1.5px solid var(--color-success);border-radius:5px}.app-booting[data-v-421a3c2f]{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--color-text-secondary);background:var(--color-bg-main)}*{box-sizing:border-box;margin:0;padding:0}:root{--color-bg-main: #f8f9f5;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f0f4ed;--color-bg-hover: #e8f0e3;--color-text-primary: #2d4a2b;--color-text-secondary: #5a7a57;--color-text-tertiary: #8b9d88;--color-primary: #4a9d8f;--color-primary-hover: #3d8a7d;--color-primary-light: #e6f4f2;--color-border: #d4e0d1;--color-border-light: #e8f0e3;--color-success: #6baf92;--color-warning: #d4a574;--color-danger: #c97a7a;--shadow-sm: 0 1px 3px rgba(45, 74, 43, .08);--shadow-md: 0 2px 8px rgba(45, 74, 43, .1);--radius-sm: 6px;--radius-md: 10px}body{font-family:Noto Sans TC,sans-serif;background:var(--color-bg-main);color:var(--color-text-primary);line-height:1.6;font-size:15px}.top-nav{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.nav-container{max-width:1600px;margin:0 auto;display:flex;align-items:center;padding:0 24px}.logo{padding:4px 20px 4px 0;margin-right:24px;border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;justify-content:center;gap:2px}.logo img{display:block;height:16px}.logo h1{font-size:12px;font-weight:700;color:var(--color-primary);line-height:1.2}.logo p{font-size:9px;color:var(--color-text-tertiary);margin-top:0;line-height:1}.nav-menu{display:flex;gap:2px;flex:1;flex-wrap:nowrap;overflow:hidden}.nav-item{padding:8px 12px;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent;display:flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background:var(--color-bg-tertiary);border-bottom-color:var(--color-primary);color:var(--color-primary);font-weight:600}.nav-badge{background:var(--color-primary);color:#fff;padding:2px 7px;border-radius:10px;font-size:11px;font-weight:700;min-width:18px;text-align:center}.main-content{max-width:1600px;margin:0 auto;padding:0 24px 20px;height:calc(100vh - 56px);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;background:var(--color-bg-main)}.page{display:none}.page.active{display:flex;flex-direction:column;flex:1}#page-tracking.active,#page-sales.active,#page-today.active{display:flex;flex-direction:column}.page-header{margin-bottom:16px;display:flex;align-items:baseline;gap:12px}.page-title{font-size:15px;font-weight:700;line-height:1;align-self:center;white-space:nowrap}.page-subtitle{font-size:13px;color:var(--color-text-secondary)}.toolbar{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.list-sticky-header{position:sticky;top:0;z-index:20;background:var(--color-bg-main);box-shadow:0 2px 6px #00000012;margin-left:-24px;margin-right:-24px;padding-left:24px;padding-right:24px;padding-top:10px}.search-icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;flex-shrink:0;transition:border-color .15s,color .15s,background .15s;padding:0}.search-icon-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.search-icon-btn.active{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.search-inline-bar{display:none;align-items:center;gap:8px;padding:6px 0 4px;border-top:1px solid var(--color-border-light);margin-top:4px}.search-inline-bar.open{display:flex}.search-inline-bar svg{flex-shrink:0;color:var(--color-text-tertiary)}.search-inline-bar input{flex:0 1 320px;min-width:160px;padding:6px 12px;background:var(--color-bg-secondary);border:1.5px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:13px;font-family:Noto Sans TC,sans-serif;outline:none;box-shadow:0 0 0 3px var(--color-primary-light)}.search-inline-clear{padding:5px 10px;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;font-family:Noto Sans TC,sans-serif;transition:border-color .15s,color .15s}.search-inline-clear:hover{border-color:var(--color-danger);color:var(--color-danger)}.search-inline-submit{padding:5px 12px;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-sm);color:#fff;font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;font-family:Noto Sans TC,sans-serif;font-weight:600;transition:background .15s}.search-inline-submit:hover{background:var(--color-primary-dark, #2a6fc7)}.search-date-range{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-left:4px}.search-date-range span{font-size:12px;color:var(--color-text-tertiary);white-space:nowrap}.search-date-range input[type=date]{padding:5px 8px;background:var(--color-bg-secondary);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:12px;font-family:Noto Sans TC,sans-serif;outline:none;cursor:pointer;transition:border-color .15s,box-shadow .15s}.search-date-range input[type=date]:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.search-date-range input[type=date].active{border-color:var(--color-primary);background:#eef4ff}.search-box,.search-btn{display:none}.search-expandable{display:contents}.search-expandable-input{display:none}.search-box input{width:100%;padding:5px 12px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:0;color:var(--color-text-primary);font-size:13px;font-family:Noto Sans TC,sans-serif}.search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.btn{padding:9px 18px;border:none;border-radius:0;font-size:14px;font-weight:600;cursor:pointer;font-family:Noto Sans TC,sans-serif;transition:all .2s}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-tertiary)}.btn-sm{padding:5px 12px;font-size:13px}.tag-multiselect{position:relative;display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:var(--color-bg-secondary);border:1px solid var(--color-border);font-size:13px;font-family:Noto Sans TC,sans-serif;font-weight:500;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0;min-width:80px;transition:border-color .15s,color .15s}.tag-multiselect.active{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.tag-multiselect-arrow{font-size:10px;opacity:.6}.tag-multiselect-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;min-width:160px;max-height:240px;overflow-y:auto;background:#fff;border:1px solid var(--color-border);border-radius:6px;box-shadow:0 4px 16px #0000001f;z-index:200;padding:4px 0}.tag-multiselect.open .tag-multiselect-dropdown{display:block}.tag-multiselect-item{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:13px;cursor:pointer;color:var(--color-text-primary);transition:background .1s}.tag-multiselect-item:hover{background:var(--color-bg-secondary)}.tag-multiselect-item input[type=checkbox]{accent-color:var(--color-primary);width:14px;height:14px;cursor:pointer}.tag-multiselect-clear{display:flex;align-items:center;justify-content:center;padding:5px 12px;font-size:12px;color:var(--color-danger);border-top:1px solid var(--color-border-light);cursor:pointer;margin-top:2px}.tag-multiselect-clear:hover{background:#fff5f5}.col-toggle-btn{position:relative;display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:var(--color-bg-secondary);border:1px solid var(--color-border);font-size:13px;font-family:Noto Sans TC,sans-serif;font-weight:500;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0;border-radius:var(--radius-sm);transition:border-color .15s,color .15s}.col-toggle-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.col-toggle-btn.open{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.col-toggle-dropdown{display:none;position:absolute;top:calc(100% + 4px);right:0;min-width:160px;background:#fff;border:1px solid var(--color-border);border-radius:6px;box-shadow:0 4px 16px #0000001f;z-index:300;padding:6px 0}.col-toggle-btn.open .col-toggle-dropdown{display:block}.col-toggle-item{display:flex;align-items:center;gap:8px;padding:6px 14px;font-size:13px;cursor:pointer;color:var(--color-text-primary);transition:background .1s}.col-toggle-item:hover{background:var(--color-bg-tertiary)}.col-toggle-item input[type=checkbox]{accent-color:var(--color-primary);width:14px;height:14px;cursor:pointer}.col-hidden{display:none!important}.toolbar-sep{width:1px;height:22px;background:var(--color-border);flex-shrink:0;align-self:center;margin:0 2px}.filter-group{display:flex;gap:4px}.filter-btn,.filter-select{padding:5px 8px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:0;font-size:12px;font-family:Noto Sans TC,sans-serif;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0;min-width:0;max-width:130px}.filter-btn:hover,.filter-select:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-tertiary)}.filter-btn:focus,.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.filter-btn.active,.filter-select.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}.card-list{display:flex;flex-direction:column;gap:4px}.prospect-card{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:0;overflow:hidden;transition:all .2s}.prospect-card:hover{border-color:var(--color-border)}.prospect-card.expanded{border-color:var(--color-border);border-radius:0;overflow:hidden}.prospect-card.has-changes{border-left:3px solid var(--color-warning)}.card-header{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .2s}.card-header:hover{background:var(--color-bg-hover)}.prospect-card.expanded .card-header{background:var(--color-primary-light);border-bottom:1px solid var(--color-border-light);padding:10px 12px;position:sticky;top:0;z-index:10}.expand-icon{color:var(--color-text-tertiary);font-size:12px;transition:transform .2s;flex-shrink:0;width:16px}.prospect-card.expanded .expand-icon{transform:rotate(90deg);color:var(--color-primary)}.card-main{flex:1;display:flex;gap:10px;align-items:center;padding-right:8px;flex-wrap:nowrap;overflow:hidden}.list-header-inner{flex:1;display:flex;gap:10px;align-items:flex-start;padding-right:8px}.card-main>.fixed-company,.card-main>.fixed-id,.card-main>.fixed-contact{gap:10px}.card-col{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;padding:0;margin:0}.card-col.fixed-company{flex:0 0 180px}.card-col.fixed-company .en-name-sub{display:block;font-size:10px;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400;margin-top:1px}.card-col.fixed-id{flex:0 0 80px}.card-col.fixed-contact{flex:0 0 56px}.card-col.fixed-phone{flex:0 0 150px}.card-col.fixed-area{flex:0 0 42px}.card-col.fixed-industry{flex:0 0 76px;overflow:hidden;white-space:nowrap}.card-col.fixed-industry .col-data{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:normal}.card-col.fixed-date{flex:0 0 72px}.card-col.fixed-caller,.card-col.fixed-stage{flex:0 0 56px}.card-col.fixed-tags{flex:0 0 160px}.card-col.fixed-edm{flex:0 0 130px}.card-col.fixed-count{flex:0 0 36px}.card-col.fixed-followup{flex:0 0 72px}.col-title{font-size:13px;font-weight:600;color:var(--color-text-tertiary);height:auto;line-height:1;padding:0;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-data{font-size:13px;color:var(--color-text-primary);word-break:break-word;white-space:normal;overflow-wrap:break-word;line-height:1.4;padding:0;margin:0}.card-col.flex-1-8 .col-data{white-space:normal;word-break:break-all}.company-name{font-size:13px;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.company-id{font-size:13px;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.contact-name{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.contact-phone{font-size:13px;font-weight:500;white-space:nowrap;color:var(--color-text-primary)}.contact-ext{font-size:13px;font-weight:500;white-space:nowrap;color:var(--color-text-secondary);min-width:0;overflow:hidden;text-overflow:ellipsis}.card-field{min-width:0;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-secondary)}.card-field.industry{color:var(--color-text-secondary)}.sort-col{cursor:pointer;display:flex;align-items:center;justify-content:flex-start;gap:2px;white-space:nowrap;font-size:13px;color:var(--color-text-tertiary);font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis}.sort-col:hover{color:var(--color-primary)}.sort-col.sort-center{justify-content:center}.sort-col .sort-arrow{font-size:9px;opacity:.3}.sort-col .sort-arrow:after{content:"⇅"}.sort-col.sort-k1 .sort-arrow{opacity:1;color:#e07b2a}.sort-col.sort-k2 .sort-arrow{opacity:1;color:#2a7be0}.sort-col.sort-k3 .sort-arrow{opacity:1;color:#888}.sort-col.sort-k1.asc .sort-arrow:after{content:"▲①"}.sort-col.sort-k1.desc .sort-arrow:after{content:"▼①"}.sort-col.sort-k2.asc .sort-arrow:after{content:"▲②"}.sort-col.sort-k2.desc .sort-arrow:after{content:"▼②"}.sort-col.sort-k3.asc .sort-arrow:after{content:"▲③"}.sort-col.sort-k3.desc .sort-arrow:after{content:"▼③"}.sort-k1-only.sort-k1.asc .sort-arrow:after{content:"▲"}.sort-k1-only.sort-k1.desc .sort-arrow:after{content:"▼"}#sort-clear-btn{display:none;font-size:11px;color:#888;cursor:pointer;padding:2px 6px;border:1px solid #ccc;border-radius:4px;margin-left:6px;white-space:nowrap;flex-shrink:0}#sort-clear-btn:hover{color:#e07b2a;border-color:#e07b2a}.edm-sort-col{display:inline-flex;align-items:center;gap:2px}.edm-sort-col:hover{color:var(--color-primary)}.edm-sort-col .edm-sort-arrow{font-size:9px;opacity:.3}.edm-sort-col .edm-sort-arrow:after{content:"⇅"}.edm-sort-col.asc .edm-sort-arrow{opacity:1;color:var(--color-primary)}.edm-sort-col.asc .edm-sort-arrow:after{content:"▲"}.edm-sort-col.desc .edm-sort-arrow{opacity:1;color:var(--color-primary)}.edm-sort-col.desc .edm-sort-arrow:after{content:"▼"}.code-editor-base{position:absolute;top:0;left:0;width:100%;height:100%;padding:12px;font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.5;-moz-tab-size:2;tab-size:2;white-space:pre-wrap;box-sizing:border-box;overflow-y:auto}.code-editor-highlight{color:#334155;background:#fff;pointer-events:none}.code-editor-textarea{border:none;resize:none;background:transparent;color:transparent;caret-color:#000;outline:none}.code-editor-wrap{position:relative;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.stage-badge{display:inline-flex;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.stage-not_contacted{background:#f5f5f5;color:#7f8c8d}.stage-contacted{background:#d4e6f1;color:#2874a6}.stage-not_needed{background:#e5e8e8;color:#5d6d7e}.stage-interested{background:#fef5e7;color:#b9770e}.stage-sales_contacted{background:#fdebd0;color:#a04000}.stage-sales_active{background:#d6eaf8;color:#1a5276}.stage-quoted{background:#d5f4e6;color:#196f3d}.stage-won{background:#d4efdf;color:#1e8449}.card-body{display:none;padding:14px;background:var(--color-bg-main)}.prospect-card.expanded .card-body{display:block}.info-grid{display:grid;grid-template-columns:100px 100px 140px 1fr 1fr 140px;gap:12px;background:var(--color-bg-secondary);padding:12px;border-radius:var(--radius-sm);margin-bottom:10px}.info-item{min-width:0;display:flex;align-items:center;gap:4px}.info-label{font-size:13px;color:var(--color-text-tertiary);font-weight:500;white-space:nowrap;flex-shrink:0}.info-label:after{content:":"}.info-value{font-size:13px;font-weight:500;line-height:1.4;white-space:nowrap}.info-value a{color:var(--color-primary);text-decoration:none}.info-notes{grid-column:1 / -1}.info-notes .info-value{white-space:normal;font-size:13px}.quick-actions{display:flex;justify-content:center;gap:8px;margin-bottom:12px}.btn-danger{background:#e67e22;color:#fff;border:none}.btn-danger:hover{background:#d35400}.call-logs-section{margin-top:12px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);padding:6px 10px}.section-title{font-size:15px;font-weight:700}.call-log-item{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);padding:0;margin-bottom:8px;font-size:12px;overflow:hidden}.call-log-header{display:flex;align-items:center;gap:0;padding:6px 10px;margin-bottom:0;background:#e4ece7;border-bottom:1px solid #c8d8cc;flex-wrap:wrap;font-size:13px}.call-log-header>*{flex-shrink:0}.clh-label{color:var(--color-text-tertiary);font-weight:400;margin-right:2px}.clh-val{font-weight:600}.clh-cell{display:inline-flex;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clh-time{margin-right:20px}.clh-window{margin-right:12px}.clh-stage{width:7em;margin-right:12px}.clh-caller{width:12ch;margin-right:12px}.clh-tags{margin-right:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clh-edm{display:inline-flex;align-items:center;gap:4px;margin-right:12px}.clh-edm-subject{width:6em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clh-edm-status{max-width:4.5em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clh-actions{margin-left:auto;display:flex;gap:8px;align-items:center;flex-shrink:0;white-space:nowrap}.clh-actions .clh-followup{color:#e53e3e;font-weight:600}.call-log-content{font-size:13px;color:#1a5276;line-height:1.6;padding:8px 10px;margin-bottom:0;margin-left:0}.call-log-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.call-tag{padding:2px 7px;border-radius:10px;font-size:13px;font-weight:500;background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.pagination-bar{display:flex;align-items:center;justify-content:center;gap:4px;padding:12px 0 4px;flex-shrink:0}.pagination-bar:empty{display:none}.pg-btn{min-width:32px;height:32px;padding:0 8px;border-radius:6px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-primary);font-size:13px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.pg-btn:hover:not(:disabled){background:var(--color-bg-secondary)}.pg-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:700}.pg-btn:disabled{opacity:.35;cursor:default}.pg-info{font-size:12px;color:var(--color-text-tertiary);padding:0 8px;white-space:nowrap}.call-log-footer{display:flex;justify-content:flex-end;font-size:12px;color:var(--color-text-tertiary)}.next-followup{color:var(--color-warning);font-weight:600}.quick-call-form{background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius-md);padding:12px;margin-bottom:10px}.form-row{display:flex;gap:10px;margin-bottom:10px}.form-group{flex:1}.form-label .req{color:#e53e3e}.form-label{font-size:12px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:8px 10px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:Noto Sans TC,sans-serif;color:var(--color-text-primary)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-textarea{min-height:70px;resize:vertical;line-height:1.5}.tag-selector{display:flex;flex-wrap:wrap;gap:5px;min-height:32px}.stage-selector{display:flex;flex-wrap:wrap;gap:5px;align-items:center}.stage-option{padding:3px 10px;border:1px solid var(--color-border);border-radius:0;font-size:12px;background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all .15s;font-weight:500;-webkit-user-select:none;user-select:none}.stage-option:hover{background:var(--color-bg-tertiary)}.stage-option.selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}.tag-option{padding:5px 10px;border:1px solid var(--color-border);border-radius:12px;font-size:12px;background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:all .2s;font-weight:500}.tag-option:hover{background:var(--color-bg-tertiary)}.tag-option.selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tag-add-btn{padding:5px 10px;border:1px dashed var(--color-border);border-radius:12px;font-size:12px;background:transparent;color:var(--color-text-tertiary);cursor:pointer;font-weight:500}.tag-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.form-actions{display:flex;gap:8px;justify-content:flex-end}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#2d4a2b80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:40px 20px;overflow-y:auto}.modal.active{display:flex;align-items:flex-start;justify-content:center}.modal-content{background:var(--color-bg-secondary);border-radius:var(--radius-md);width:100%;max-width:500px;box-shadow:var(--shadow-md);margin:auto}.modal-header{padding:20px;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:18px;font-weight:700}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-tertiary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--color-bg-tertiary)}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--color-border-light);display:flex;justify-content:flex-end;gap:10px}.side-panel-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000040;z-index:200}.side-panel-overlay.open{display:block}.side-panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:90vw;background:var(--color-bg-main);box-shadow:-4px 0 20px #00000026;z-index:201;transform:translate(100%);transition:transform .25s ease;display:flex;flex-direction:column;overflow:hidden}.side-panel.open{transform:translate(0)}.side-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.side-panel-header h3{font-size:16px;font-weight:700;margin:0}.side-panel-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.side-panel-close:hover{color:var(--color-text-primary)}.side-panel-body{flex:1;overflow-y:auto;padding:16px 20px}.tag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-top:12px}.tag-card{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);padding:12px;display:flex;justify-content:space-between;align-items:center}.tag-card-name{font-size:14px;font-weight:600}.tag-delete-btn{padding:4px 8px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;font-size:12px;transition:all .2s}.tag-delete-btn:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.settings-col{display:flex;flex-direction:column;gap:16px}.settings-section{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:var(--radius-md);overflow:hidden}.settings-section-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border-light)}.settings-section-icon{font-size:17px;line-height:1;flex-shrink:0}.settings-section-title{font-size:14px;font-weight:700;color:var(--color-text-primary);line-height:1.3}.settings-section-desc{font-size:11px;color:var(--color-text-tertiary);margin-top:1px;line-height:1.3}.settings-section-body{padding:14px 16px}.tags-flow-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;min-height:32px}.tags-flow-list:empty:before{content:"尚無資料";color:var(--color-text-tertiary);font-size:12px;line-height:32px}.tags-flow-list .tag-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:20px;font-size:13px;font-weight:500;color:var(--color-text-primary);transition:all .15s}.tags-flow-list .tag-pill:hover{border-color:var(--color-danger)}.tags-flow-list .tag-pill .tag-remove{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:transparent;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:12px;line-height:1;transition:all .15s}.tags-flow-list .tag-pill .tag-remove:hover{background:var(--color-danger);color:#fff}.tags-add-row{display:flex;gap:8px}.tags-add-row .form-input{flex:1;font-size:13px;padding:6px 10px}.stage-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid var(--color-border-light);border-radius:var(--radius-sm);margin-bottom:5px;background:var(--color-bg-main);transition:border-color .15s}.stage-item:hover{border-color:var(--color-primary)}.stage-item-num{font-size:11px;color:var(--color-text-tertiary);flex-shrink:0;width:18px;text-align:right}.stage-item-label{flex:1;font-size:13px;padding:3px 7px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;transition:all .15s;font-weight:500;color:var(--color-text-primary)}.stage-item-label:focus{border-color:var(--color-primary);background:#fff;outline:none}.stage-item-key{font-size:10px;font-family:SF Mono,Consolas,monospace;color:var(--color-text-tertiary);background:var(--color-bg-tertiary);padding:2px 6px;border-radius:3px;flex-shrink:0;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stage-item-del{padding:2px 8px;font-size:11px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:all .15s;flex-shrink:0}.stage-item-del:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.stage-add-form{display:flex;gap:7px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--color-border-light)}.stage-add-form .form-input{font-size:13px;padding:6px 10px;flex:1}.stage-add-form .form-input:first-child{max-width:120px}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-tertiary)}.empty-state h3{font-size:16px;margin-bottom:6px;color:var(--color-text-secondary)}.loading{text-align:center;padding:30px;color:var(--color-text-secondary)}.mt-2{margin-top:8px}.mb-2{margin-bottom:8px}#auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0fdf4,#dcf5ec)}#auth-overlay.hidden{display:none}.auth-card{background:#fff;border-radius:18px;box-shadow:0 8px 40px #2d4a2b21;padding:40px 36px 36px;width:380px;max-width:96vw}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo img{height:38px;margin-bottom:6px}.auth-logo p{font-size:12px;color:#9aab97;letter-spacing:.5px}.auth-title{font-size:17px;font-weight:700;color:#2d4a2b;text-align:center;margin-bottom:22px}.auth-field{margin-bottom:16px}.auth-field label{display:block;font-size:12px;font-weight:600;color:#6b7a68;margin-bottom:5px;letter-spacing:.3px}.auth-field input{width:100%;padding:10px 13px;border:1.5px solid #d8e6d4;border-radius:9px;font-size:14px;background:#fafcfa;transition:border-color .2s;font-family:inherit}.auth-field input:focus{outline:none;border-color:#4a9d8f;background:#fff}.auth-btn{width:100%;padding:11px;background:#2d6a4f;color:#fff;border:none;border-radius:9px;font-size:15px;font-weight:700;cursor:pointer;margin-top:4px;transition:background .2s;font-family:inherit}.auth-btn:hover{background:#235a40}.auth-btn:disabled{background:#a0b8ae;cursor:not-allowed}.auth-btn.secondary{background:#fff;color:#4a9d8f;border:1.5px solid #4a9d8f;font-weight:600;font-size:14px;margin-top:8px}.auth-btn.secondary:hover{background:#f0fdf9}.auth-error{color:#c0392b;font-size:12px;background:#fdf3f3;border:1px solid #f5c6cb;border-radius:7px;padding:8px 12px;margin-bottom:14px;display:none}.auth-success{color:#155724;font-size:12px;background:#d4edda;border:1px solid #c3e6cb;border-radius:7px;padding:8px 12px;margin-bottom:14px;display:none}.auth-link{text-align:center;margin-top:14px;font-size:13px;color:#9aab97}.auth-link a{color:#4a9d8f;text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.auth-divider{border:none;border-top:1px solid #e8f0e3;margin:18px 0}#app{min-height:100vh}
