.alert{align-items:flex-start;animation:fadeInUp .3s ease-out;border-radius:var(--border-radius-md);display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.alert-danger{background-color:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger)}.alert-success{background-color:var(--color-success-light);border:1px solid var(--color-success);color:var(--color-success)}.alert-icon{flex-shrink:0;font-size:18px}.alert-content{flex:1 1}.alert-title{font-weight:500;margin-bottom:var(--spacing-xs)}.alert-message{font-size:14px}.form-group{animation:fadeInUp .5s ease-out backwards;margin-bottom:var(--spacing-lg)}.form-group label{display:block}.input-wrapper{position:relative}.input-icon{color:var(--color-text-secondary);font-size:16px;left:var(--spacing-md);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.input-wrapper .form-control{background-color:var(--color-background);border:2px solid var(--color-border-light);border-radius:var(--border-radius-md);color:var(--color-text-primary);display:block;font-size:16px;line-height:1.5;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 48px;transition:border-color var(--transition-normal),box-shadow var(--transition-normal);width:100%}.input-wrapper .form-control:focus{background-color:var(--color-background-light);border-color:var(--color-primary-dark);box-shadow:0 0 0 4px #ffa00033;outline:0}.input-wrapper .form-control::placeholder{color:var(--color-text-secondary);opacity:.6}.input-wrapper .form-control.is-invalid{border-color:var(--color-danger)}.input-wrapper .form-control.is-invalid:focus{box-shadow:0 0 0 4px #f4433633}.invalid-feedback{display:block}.password-toggle{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:16px;padding:var(--spacing-xs);position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);transition:color var(--transition-normal)}.password-toggle:hover{color:var(--color-text-primary)}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:var(--z-index-modal)}.modal{animation:modalFadeIn .3s ease-out;background-color:var(--color-background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-large);max-width:400px;overflow:hidden;width:90%}.modal-header{background-color:var(--color-primary-light);justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.modal-header,.modal-header h3{align-items:center;display:flex}.modal-header h3{gap:var(--spacing-sm);margin:0}.modal-close{align-items:center;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.modal-close:hover{color:var(--color-text-primary)}.modal-body{padding:var(--spacing-lg)}.modal-footer{border-top:1px solid var(--color-border-light);display:flex;justify-content:flex-end;padding:var(--spacing-md) var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.login-page{background:linear-gradient(135deg,var(--color-background) 0,var(--color-primary-light) 50%,var(--color-background) 100%);display:flex;flex-direction:column;min-height:100vh}.login-container{align-items:center;display:flex;flex:1 1;justify-content:center;padding:var(--spacing-lg)}.login-wrapper{animation:fadeInUp .5s ease-out;background-color:var(--color-background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-large);max-width:450px;width:100%}.login-form-container{padding:var(--spacing-xxl)}.login-header{margin-bottom:var(--spacing-xl);text-align:center}.system-title{color:var(--color-primary-dark);font-size:32px;font-weight:700;margin:0 0 var(--spacing-md)}.login-header h1{color:var(--color-text-primary);font-size:24px;font-weight:700;margin:0 0 var(--spacing-xs)}.login-header p{color:var(--color-text-secondary);font-size:14px;margin:0}.login-form{width:100%}.form-options{animation:fadeInUp .5s ease-out .3s backwards;justify-content:space-between;margin-bottom:var(--spacing-lg)}.form-options,.remember-me{align-items:center;display:flex}.remember-me{cursor:pointer;gap:var(--spacing-sm)}.remember-me input[type=checkbox]{accent-color:var(--color-primary-dark);cursor:pointer;height:18px;width:18px}.remember-me span{color:var(--color-text-secondary);font-size:14px}.forgot-password{background:none;border:none;color:var(--color-primary-dark);cursor:pointer;font-size:14px;padding:0;transition:color var(--transition-normal)}.forgot-password:hover{color:var(--color-text-primary);text-decoration:underline}.btn{border-radius:var(--border-radius-md);font-size:16px;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);box-shadow:0 4px 15px #ffa0004d}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #ffa00066;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.7}.btn-block{animation:fadeInUp .5s ease-out .4s backwards;width:100%}.btn-lg{font-size:18px;padding:var(--spacing-md) var(--spacing-xl)}.btn-loading{color:#0000!important;position:relative}.btn-loading:after{animation:spin .8s linear infinite;border:2px solid var(--color-text-primary);border-radius:50%;border-top:2px solid #0000;content:"";height:20px;position:absolute;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.divider{align-items:center;display:flex;margin:var(--spacing-lg) 0}.divider:after,.divider:before{background-color:var(--color-border-light);content:"";flex:1 1;height:1px}.divider span{color:var(--color-text-secondary);font-size:12px;padding:0 var(--spacing-md)}.role-info{background-color:var(--color-background);border-radius:var(--border-radius-md);padding:var(--spacing-md)}.role-info-title{color:var(--color-text-secondary);font-size:12px;margin-bottom:var(--spacing-sm);text-align:center}.role-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:center}.role-badge{gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.login-footer{color:var(--color-text-secondary);font-size:12px;padding:var(--spacing-lg);text-align:center}.login-footer a{color:var(--color-primary-dark);text-decoration:none}.login-footer a:hover{text-decoration:underline}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.login-container{padding:var(--spacing-md)}.login-form-container{padding:var(--spacing-lg)}.form-options{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}.role-badges{align-items:center;flex-direction:column}.system-title{font-size:24px}}.modal-lg{max-width:600px}.form-row{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr;margin-bottom:var(--spacing-md)}.form-group label{font-size:14px}.form-control:disabled{background-color:var(--color-background)}.form-control.is-invalid{border-color:var(--color-danger)}.invalid-feedback{color:var(--color-danger);font-size:12px;margin-top:var(--spacing-xs)}.btn-secondary{background-color:var(--color-text-secondary);color:#fff}@media (max-width:768px){.form-row{grid-template-columns:1fr}}.page-header{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary-dark));padding:var(--spacing-sm) 0;position:sticky;top:0;z-index:200}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 var(--spacing-lg)}.logo h1{color:var(--color-text-primary);font-size:20px;margin:0}.header-nav{align-items:center;display:flex;gap:var(--spacing-xs)}.header-nav-btn{background:#fff3;border:none;border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;font-family:var(--font-family);font-size:13px;font-weight:500;padding:6px 14px;transition:all var(--transition-fast);white-space:nowrap}.header-nav-btn:hover{background:#ffffff80;transform:translateY(-1px)}.header-nav-btn.active{background:#ffa00059;border-bottom:2px solid var(--color-primary-dark);font-weight:700}.current-user,.header-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.current-user{background-color:#ffffff4d;border-radius:var(--border-radius-pill);font-size:14px;padding:var(--spacing-xs) var(--spacing-md)}.current-user-avatar{background-color:var(--color-primary-dark);border-radius:50%;color:#fff;display:flex;font-weight:700;height:28px;justify-content:center;width:28px}.current-user-avatar,.role-badge{align-items:center;font-size:12px}.role-badge{border-radius:var(--border-radius-pill);display:inline-flex;font-weight:500;gap:4px;padding:2px 8px}.role-badge-manager{background-color:#ffcdd2;color:#c62828}.role-badge-purchaser{background-color:#c8e6c9;color:#2e7d32}.role-badge-sales{background-color:#bbdefb;color:#1565c0}.btn{box-shadow:var(--shadow-small);font-size:14px;gap:var(--spacing-sm)}.btn:hover{box-shadow:var(--shadow-medium)}.btn-outline{box-shadow:none}.btn-outline:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.btn-sm{font-size:14px;padding:6px 16px}@media (max-width:768px){.header-content{flex-direction:column;gap:var(--spacing-sm)}}.exchange-rate-section .rate-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(4,1fr);margin-bottom:var(--spacing-md)}.exchange-rate-section .rate-item .form-group{margin-bottom:0}.exchange-rate-section .rate-input-wrapper{align-items:center;display:flex;gap:var(--spacing-sm)}.exchange-rate-section .rate-unit{color:var(--color-text-secondary);font-size:var(--font-size-sm);white-space:nowrap}.exchange-rate-section .rate-updated{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.exchange-rate-section .rate-actions{display:flex;justify-content:flex-end}@media (max-width:768px){.exchange-rate-section .rate-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.exchange-rate-section .rate-grid{grid-template-columns:1fr}}.exchange-rate-history-section .history-table-container{margin-top:var(--spacing-md);overflow-x:auto}.exchange-rate-history-section .history-table{border-collapse:collapse;font-size:14px;width:100%}.exchange-rate-history-section .history-table th{background-color:var(--color-primary-light);border-bottom:2px solid var(--color-primary);color:var(--color-text-primary);font-weight:500;padding:var(--spacing-sm) var(--spacing-md);text-align:left;white-space:nowrap}.exchange-rate-history-section .history-table td{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-sm) var(--spacing-md);vertical-align:middle}.exchange-rate-history-section .history-table tr:hover{background-color:var(--color-background)}.exchange-rate-history-section .history-empty{color:var(--color-text-secondary);padding:var(--spacing-xxl);text-align:center}@media (max-width:768px){.exchange-rate-history-section .history-table-container{overflow-x:auto}.exchange-rate-history-section .history-table{min-width:600px}}.search-filter-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.search-box{flex:1 1;max-width:400px;position:relative}.search-icon{color:var(--color-text-secondary);font-size:16px;left:var(--spacing-md);position:absolute;top:50%;transform:translateY(-50%)}.search-input{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:14px;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 40px;transition:border-color var(--transition-normal);width:100%}.search-input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 .2rem #ffd54f40;outline:none}.filter-select{appearance:none;background-color:var(--color-background-light);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%235D4037' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E");background-position:right var(--spacing-md) center;background-repeat:no-repeat;background-size:16px 12px;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;font-size:14px;padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-xl);transition:border-color var(--transition-normal);width:150px}.filter-select:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 .2rem #ffd54f40;outline:none}@media (max-width:768px){.search-filter-bar{flex-direction:column}.search-box{max-width:none}.filter-select{width:100%}}.table-container{margin-top:var(--spacing-md);overflow-x:auto}.user-table{border-collapse:collapse;font-size:14px;width:100%}.user-table th{background-color:var(--color-primary-light);border-bottom:2px solid var(--color-primary);color:var(--color-text-primary);font-weight:500;text-align:left;white-space:nowrap}.user-table td,.user-table th{padding:var(--spacing-sm) var(--spacing-md)}.user-table td{border-bottom:1px solid var(--color-border-light);vertical-align:middle}.user-table tr:hover{background-color:var(--color-background)}.user-cell{gap:var(--spacing-sm)}.user-avatar-sm,.user-cell{align-items:center;display:flex}.user-avatar-sm{background-color:var(--color-primary);border-radius:50%;color:var(--color-text-primary);flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.user-name-cell{color:var(--color-text-primary);font-weight:500}.user-email{color:var(--color-text-secondary);font-size:12px}.status-badge{font-size:12px;padding:4px 12px}.status-active{background-color:var(--color-success-light);color:var(--color-success-dark)}.status-inactive{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.action-buttons{display:flex;gap:var(--spacing-xs)}.btn-icon{align-items:center;background-color:initial;border:1px solid var(--color-primary-dark);border-radius:50%;box-shadow:none;color:var(--color-primary-dark);cursor:pointer;display:inline-flex;font-size:14px;height:28px;justify-content:center;padding:0;transition:all var(--transition-normal);width:28px}.btn-icon:hover{background-color:var(--color-primary-light);transform:scale(1.1)}.btn-icon-danger{background-color:var(--color-danger);border-color:var(--color-danger-dark);color:#fff}.btn-icon-danger:hover{background-color:var(--color-danger-dark)}.empty-state{color:var(--color-text-secondary);padding:var(--spacing-xxl);text-align:center}@media (max-width:768px){.table-container{overflow-x:auto}.user-table{min-width:800px}}.accounts-page{background-color:var(--color-background);display:flex;flex-direction:column;min-height:100vh}.main-container{margin:0 auto;max-width:1200px;width:100%}.main-container,.section{padding:var(--spacing-lg)}.section{background-color:var(--color-background-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);margin-bottom:var(--spacing-lg)}.section-header{align-items:center;border-bottom:2px solid var(--color-primary);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.section-header h2{display:flex;font-size:18px;gap:var(--spacing-sm);margin:0}.section-header h2,.section-number{align-items:center;color:var(--color-text-primary)}.section-number{background-color:var(--color-primary);border-radius:50%;display:inline-flex;font-size:14px;font-weight:700;height:28px;justify-content:center;width:28px}@media (max-width:768px){.main-container{padding:var(--spacing-md)}.section-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}.btn-primary{width:100%}}.customer-filter-section{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.filter-section-title{font-size:var(--font-size-md)}.deal-filter{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.deal-filter-btn{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-md);transition:all var(--transition-normal)}.deal-filter-btn:hover{transform:translateY(-1px)}.deal-filter-btn.active.all{background-color:var(--color-primary-light);border-color:var(--color-primary-dark);font-weight:var(--font-weight-medium)}.deal-filter-btn.active.yes{background-color:var(--color-success-light);border-color:var(--color-success);color:var(--color-success-dark);font-weight:var(--font-weight-medium)}.deal-filter-btn.active.no{background-color:#e9ecef;border-color:#adb5bd;color:#495057;font-weight:var(--font-weight-medium)}.customer-action-bar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.customer-action-bar,.customer-table-container{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small)}.customer-table-container{margin-bottom:var(--spacing-md);max-height:65vh;overflow:auto}.customer-table{border-collapse:collapse;font-size:var(--font-size-sm);min-width:1100px;width:100%}.customer-table thead{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));position:sticky;top:0;z-index:4}.customer-table th{background:inherit;border-bottom:2px solid var(--color-primary-dark);color:var(--color-text-primary);font-weight:var(--font-weight-medium);text-align:left;white-space:nowrap}.customer-table td,.customer-table th{padding:var(--spacing-sm) var(--spacing-md)}.customer-table td{border-bottom:1px solid var(--color-border-light);vertical-align:middle}.customer-table tbody tr:hover{background-color:var(--color-primary-light)}.customer-table tbody tr:last-child td{border-bottom:none}.customer-name{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.status-deal-yes{background-color:var(--color-success-light);color:var(--color-success-dark)}.status-deal-no{background-color:#e9ecef;color:#6c757d}.customer-modal-overlay{align-items:center;background-color:#00000073;bottom:0;display:none;justify-content:center;left:0;padding:var(--spacing-lg);position:fixed;right:0;top:0;z-index:var(--z-index-modal)}.customer-modal-overlay.open{display:flex}.customer-modal{animation:modal-in .25s ease;background-color:var(--color-background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-large);display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;width:100%}@keyframes modal-in{0%{opacity:0;transform:translateY(-20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.customer-modal .modal-header{align-items:center;background:linear-gradient(135deg,#ffd54f4d,#ffa00033);border-bottom:1px solid var(--color-border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.customer-modal .modal-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);gap:var(--spacing-sm);margin:0}.customer-modal .modal-close{background:#0000;border:none;border-radius:50%;color:var(--color-text-secondary);cursor:pointer;font-size:22px;line-height:1;padding:var(--spacing-xs);transition:background-color var(--transition-fast)}.customer-modal .modal-close:hover{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.customer-modal .modal-body{flex:1 1;overflow-y:auto;padding:var(--spacing-lg)}.customer-modal .modal-footer{background-color:#fff9e680;border-top:1px solid var(--color-border-light);flex-shrink:0;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.customer-modal .modal-footer,.customer-modal .modal-footer-right{display:flex;gap:var(--spacing-sm)}.meta-info-row{background-color:var(--color-background);border:1px solid var(--color-border-light);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);gap:var(--spacing-lg);justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-md)}.meta-info-row,.meta-item{align-items:center;display:flex}.meta-item{flex:1 1;gap:var(--spacing-xs)}.meta-label{color:var(--color-text-secondary);white-space:nowrap}.meta-value{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.meta-deal-group{align-items:center;flex-shrink:0}.meta-deal-group,.toggle-group{display:flex;gap:var(--spacing-sm)}.toggle-btn{background-color:var(--color-background-light);border:2px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:3px var(--spacing-sm);text-align:center;transition:all var(--transition-normal);white-space:nowrap}.toggle-btn:hover{border-color:var(--color-primary-dark)}.toggle-btn.deal-yes.active{background-color:var(--color-success-light);border-color:var(--color-success);color:var(--color-success-dark)}.toggle-btn.deal-no.active{background-color:#e9ecef;border-color:#adb5bd;color:#495057}.form-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg)}.form-grid-4{grid-template-columns:repeat(4,1fr)}.form-group.full-width{grid-column:1/-1}.form-group.span-2{grid-column:span 2}.required-mark{font-weight:var(--font-weight-bold)}.contacts-section{border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);margin-bottom:0;overflow:hidden}.contacts-section-header{align-items:center;background:linear-gradient(135deg,#ffd54f33,#ffa0001a);border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.contacts-section-label{font-size:var(--font-size-sm)}.contacts-add-btn,.contacts-section-label{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.contacts-add-btn{align-items:center;background-color:var(--color-primary-light);border:1px solid var(--color-primary-dark);border-radius:var(--border-radius-sm);cursor:pointer;display:inline-flex;font-family:var(--font-family);font-size:var(--font-size-xs);gap:var(--spacing-xs);padding:4px var(--spacing-sm);transition:all var(--transition-fast)}.contacts-add-btn:hover{background-color:var(--color-primary);transform:translateY(-1px)}.contact-row{background-color:var(--color-background-light);border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.contact-row:last-child{border-bottom:none}.contact-row:hover{background-color:#fff9e6cc}.contact-row-header{align-items:center;background-color:#fff9e699;border-bottom:1px dashed var(--color-border-light);display:flex;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-md)}.contact-row-num{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.contact-remove-btn{align-items:center;background-color:initial;border:1px solid var(--color-danger-light);border-radius:50%;color:var(--color-danger);cursor:pointer;display:inline-flex;font-size:14px;height:24px;justify-content:center;line-height:1;padding:0;transition:all var(--transition-fast);width:24px}.contact-remove-btn:hover{background-color:var(--color-danger);border-color:var(--color-danger);color:var(--color-text-inverse)}.contact-remove-btn:disabled{cursor:not-allowed;opacity:.3}.contact-row-fields{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr 2fr 1fr;padding:var(--spacing-md)}.contact-row-fields .form-group{margin-bottom:0}.level-badge{align-items:center;border-radius:var(--border-radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);height:24px;justify-content:center;min-width:36px;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap}.level-a{background-color:#fce4ec;color:#c62828}.level-b{background-color:#fff3e0;color:#e65100}.level-c{background-color:#e8f5e9;color:#2e7d32}.level-d{background-color:#e3f2fd;color:#1565c0}.level-none{background-color:#f5f5f5;color:#9e9e9e}.level-filter{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.level-filter-btn{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-md);transition:all var(--transition-normal)}.level-filter-btn:hover{transform:translateY(-1px)}.level-filter-btn.active.all{background-color:var(--color-primary-light);border-color:var(--color-primary-dark);font-weight:var(--font-weight-medium)}.level-filter-btn.active.a{background-color:#fce4ec;border-color:#c62828;color:#c62828;font-weight:var(--font-weight-medium)}.level-filter-btn.active.b{background-color:#fff3e0;border-color:#e65100;color:#e65100;font-weight:var(--font-weight-medium)}.level-filter-btn.active.c{background-color:#e8f5e9;border-color:#2e7d32;color:#2e7d32;font-weight:var(--font-weight-medium)}.level-filter-btn.active.d{background-color:#e3f2fd;border-color:#1565c0;color:#1565c0;font-weight:var(--font-weight-medium)}.level-filter-btn.active.none{background:#f5f5f5;border-color:#757575;color:#424242;font-weight:var(--font-weight-medium)}.toggle-btn.level-none.active{background-color:#f5f5f5;border-color:#9e9e9e;color:#616161}.toggle-btn.level-a.active{background-color:#fce4ec;border-color:#c62828;color:#c62828}.toggle-btn.level-b.active{background-color:#fff3e0;border-color:#e65100;color:#e65100}.toggle-btn.level-c.active{background-color:#e8f5e9;border-color:#2e7d32;color:#2e7d32}.toggle-btn.level-d.active{background-color:#e3f2fd;border-color:#1565c0;color:#1565c0}.view-mode .form-control{background-color:var(--color-background-dark);border-color:var(--color-border-light);cursor:default;pointer-events:none}.view-mode textarea.form-control{resize:none}.view-mode .toggle-btn{opacity:.85;pointer-events:none}.view-mode .contact-remove-btn,.view-mode .contacts-add-btn{display:none!important}@media (max-width:768px){.customer-action-bar,.filter-row{flex-direction:column}.customer-action-bar{align-items:stretch}.form-grid-4{grid-template-columns:1fr}.form-group.span-2{grid-column:span 1}.contact-row-fields{grid-template-columns:1fr 1fr}.pagination-container{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.customer-modal{max-height:95vh}.meta-info-row{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}}.page-header{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));box-shadow:var(--shadow-medium);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg) var(--spacing-xl)}.page-header h1{color:var(--color-text-primary);font-size:var(--font-size-xxl);font-weight:var(--font-weight-bold);margin:0}.filter-group label{display:block}.filter-group .form-control{box-sizing:border-box;height:40px}.cascading-filters{align-items:flex-end;display:flex;gap:var(--spacing-md)}.cascading-filters .filter-group{flex:1 1}.cascading-arrow{color:var(--color-text-secondary);font-size:var(--font-size-lg);padding-bottom:var(--spacing-sm)}.tag-dropdown{position:relative}.tag-dropdown-trigger{align-items:center;cursor:pointer;display:flex;justify-content:space-between;-webkit-user-select:none;user-select:none}.tag-dropdown-placeholder{color:var(--color-text-secondary);opacity:.6}.tag-dropdown-arrow{color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:transform var(--transition-fast)}.tag-dropdown.open .tag-dropdown-arrow{transform:rotate(180deg)}.tag-dropdown-menu{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:0 0 var(--border-radius-sm) var(--border-radius-sm);border-top:none;box-shadow:var(--shadow-small);display:none;grid-template-columns:repeat(5,1fr);left:0;max-height:200px;overflow-y:auto;padding:var(--spacing-xs);position:absolute;right:0;top:100%;z-index:100;z-index:var(--z-index-dropdown,100)}.tag-dropdown.open .tag-dropdown-menu{display:grid}.tag-dropdown-item{align-items:center;border-radius:var(--border-radius-sm);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);margin-bottom:0;padding:var(--spacing-xs) var(--spacing-sm);transition:background-color var(--transition-fast);white-space:nowrap}.tag-dropdown-item:hover{background-color:var(--color-primary-light)}.tag-dropdown-item input[type=checkbox]{accent-color:var(--color-primary-dark);cursor:pointer}.tag{align-items:center;background-color:var(--color-primary-light);border-radius:9999px;border-radius:var(--border-radius-pill,9999px);color:var(--color-text-primary);display:inline-flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.tag-remove{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:14px;line-height:1;opacity:.6;padding:0}.tag-remove:hover{color:var(--color-danger);opacity:1}.status-filter{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.status-filter-item{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-md);transition:all var(--transition-normal);-webkit-user-select:none;user-select:none}.status-filter-item:hover{transform:translateY(-1px)}.status-filter-item.active{font-weight:var(--font-weight-medium)}.status-filter-item.status-unprocessed{border-color:var(--color-danger)}.status-filter-item.status-unprocessed.active{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.status-filter-item.status-catalog{border-color:var(--color-warning)}.status-filter-item.status-catalog.active{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.status-filter-item.status-to-web{border-color:var(--color-info)}.status-filter-item.status-to-web.active{background-color:var(--color-info-light);color:var(--color-info-dark)}.status-filter-item.status-online{border-color:var(--color-success)}.status-filter-item.status-online.active{background-color:var(--color-success-light);color:var(--color-success-dark)}.status-filter-item.status-none{border-color:#9e9e9e}.status-filter-item.status-none.active{background-color:#e0e0e0;color:#616161}.action-group-label{margin-right:var(--spacing-xs)}.quick-filter-btn{background-color:#e9ecef;border:1px solid #ced4da;color:#495057;padding:var(--spacing-xs) var(--spacing-md)}.quick-filter-btn:hover{background-color:#dee2e6;border-color:#adb5bd;box-shadow:var(--shadow-small);transform:translateY(-2px)}.quick-filter-btn.active{background-color:#fff3e0;border-color:#ff9800;color:#e65100;font-weight:var(--font-weight-medium)}.products-table-container{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);max-height:70vh;overflow-x:auto;overflow-y:scroll}.products-data-table{border-collapse:collapse;font-size:var(--font-size-sm);width:100%}.products-data-table thead{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));position:sticky;top:0;z-index:4}.products-data-table th{background:inherit;border-bottom:2px solid var(--color-primary-dark);color:var(--color-text-primary);font-weight:var(--font-weight-medium);line-height:1.2;padding:var(--spacing-xs) var(--spacing-sm);text-align:left;white-space:nowrap}.products-data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.products-data-table th.sortable:hover{background-color:#ffa00033}.products-data-table td.col-actions,.products-data-table td.col-checkbox,.products-data-table td.col-status{text-align:center}.products-data-table td:first-child,.products-data-table th:first-child{left:0;position:sticky;z-index:2}.products-data-table thead th:first-child{z-index:5}.products-data-table td:nth-child(2),.products-data-table th:nth-child(2){left:40px;position:sticky;z-index:2}.products-data-table thead th:nth-child(2){z-index:5}.products-data-table tbody td:first-child,.products-data-table tbody td:nth-child(2){background-color:var(--color-background-light)}.products-data-table tbody tr:hover td:first-child,.products-data-table tbody tr:hover td:nth-child(2){background-color:var(--color-primary-light)}.products-data-table tbody tr{background-color:var(--color-background-light);transition:background-color var(--transition-normal)}.products-data-table tbody tr:hover{background-color:var(--color-primary-light)}.products-data-table td{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) var(--spacing-sm);vertical-align:middle}.product-info{display:flex;flex-direction:column;gap:2px}.product-code{color:var(--color-text-secondary);font-family:monospace;font-size:var(--font-size-xs);font-weight:var(--font-weight-regular)}.product-name{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.product-name-en{color:#6d4c41;color:var(--color-text-light,#6d4c41);font-size:11px;font-style:italic}.cbm-badge{align-items:center;border-radius:3px;display:inline-flex;font-size:10px;gap:2px;margin-left:var(--spacing-xs);padding:1px 4px}.cbm-auto{background-color:var(--color-info-light);color:var(--color-info-dark)}.cbm-vendor{background-color:var(--color-success-light);color:var(--color-success-dark)}.cbm-estimate{color:var(--color-warning-dark)}.cbm-estimate,.cbm-estimate-highlight{background-color:var(--color-warning-light)}.cbm-estimate-highlight{border-radius:var(--border-radius-sm);display:inline-block;padding:2px 6px}.cost-source-badge{margin-right:var(--spacing-sm);padding:2px 6px}.price-cell{font-family:Noto Sans TC,sans-serif;font-size:var(--font-size-xs);white-space:nowrap}.status-badge-warning{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.status-badge-secondary{background-color:#e9ecef;color:#6c757d}.row-actions{flex-wrap:nowrap}.btn-detail{background-color:var(--color-primary);color:var(--color-text-primary)}.btn-detail:hover{background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.batch-edit-bar{align-items:center;animation:batch-bar-in .2s ease;background:linear-gradient(135deg,#2196f31a,#2196f30d);border:1px solid #2196f3;border:1px solid var(--color-info,#2196f3);border-radius:var(--border-radius-md);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg)}@keyframes batch-bar-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.batch-edit-bar-info{color:#1565c0;color:var(--color-info-dark,#1565c0);font-size:var(--font-size-sm)}.batch-edit-bar-actions{display:flex;gap:var(--spacing-sm)}.btn-batch-save{background-color:#4caf50;background-color:var(--color-success,#4caf50);border:1px solid #4caf50;border:1px solid var(--color-success,#4caf50);color:#fff}.btn-batch-save:hover:not(:disabled){background-color:#388e3c;background-color:var(--color-success-dark,#388e3c)}.btn-batch-save:disabled{cursor:not-allowed;opacity:.6}.btn-batch-cancel{background-color:#e9ecef;border:1px solid #ced4da;color:#495057}.btn-batch-cancel:hover:not(:disabled){background-color:#dee2e6}.batch-edit-row{background-color:#2196f30a}.batch-edit-row:hover{background-color:#2196f314!important}.batch-edit-input{border:1px solid #2196f3!important;border:1px solid var(--color-info,#2196f3)!important;font-size:var(--font-size-sm)!important;min-width:60px;padding:4px 6px!important;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.batch-edit-input:focus{border-color:#1565c0!important;border-color:var(--color-info-dark,#1565c0)!important;box-shadow:0 0 0 2px #2196f333}.product-modal-overlay{align-items:center;background-color:#00000073;bottom:0;display:none;justify-content:center;left:0;padding:var(--spacing-lg);position:fixed;right:0;top:0;z-index:400;z-index:var(--z-index-modal,400)}.product-modal-overlay.open{display:flex}.product-modal{animation:product-modal-in .25s ease;background-color:var(--color-background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-large);display:flex;flex-direction:column;max-height:92vh;max-width:960px;overflow:hidden;width:100%}@keyframes product-modal-in{0%{opacity:0;transform:translateY(-20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.product-modal .modal-header{align-items:center;background:linear-gradient(135deg,#ffd54f4d,#ffa00033);border-bottom:1px solid var(--color-border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.product-modal .modal-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);gap:var(--spacing-sm);margin:0}.product-modal .modal-close{background:#0000;border:none;border-radius:50%;color:var(--color-text-secondary);cursor:pointer;font-size:22px;line-height:1;padding:var(--spacing-xs);transition:background-color var(--transition-fast)}.product-modal .modal-close:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.product-tabs{background-color:var(--color-background);border-bottom:2px solid var(--color-border-light);display:flex;flex-shrink:0;overflow-x:auto}.product-tab-btn{background:none;border:none;border-bottom:3px solid #0000;color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:-2px;padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);white-space:nowrap}.product-tab-btn:hover{background-color:var(--color-primary-light);color:var(--color-primary-dark)}.product-tab-btn.active{background-color:var(--color-background-light);border-bottom-color:var(--color-primary-dark);color:var(--color-primary-dark)}.product-modal .modal-body{flex:1 1;overflow-y:auto;padding:var(--spacing-lg)}.product-modal .modal-footer{background-color:#fff9e680;border-top:1px solid var(--color-border-light);flex-shrink:0;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.product-modal .modal-footer,.product-modal .modal-footer-right{display:flex;gap:var(--spacing-sm)}.product-section-header{background:linear-gradient(135deg,#ffd54f33,#ffa0001a);border-left:3px solid var(--color-primary-dark);border-radius:var(--border-radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-md)}.product-form-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md)}.product-form-grid-2{grid-template-columns:repeat(2,1fr)}.product-form-grid-3{grid-template-columns:repeat(3,1fr)}.product-form-grid-4{grid-template-columns:repeat(4,1fr)}.product-form-grid-5{grid-template-columns:repeat(5,1fr)}.product-form-grid .full-width{grid-column:1/-1}.product-form-grid .span-2{grid-column:span 2}.product-form-grid .span-3{grid-column:span 3}.product-dropdown-row{align-items:center;display:flex;gap:var(--spacing-xs)}.product-dropdown-row select{flex:1 1}.product-dropdown-manage-btn{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;font-family:var(--font-family);font-size:14px;padding:4px 8px;transition:all var(--transition-fast);white-space:nowrap}.product-dropdown-manage-btn:hover{background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}.option-manager-panel{background-color:var(--color-background);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);margin-top:var(--spacing-sm);padding:var(--spacing-md)}.option-manager-header{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);justify-content:space-between;margin-bottom:var(--spacing-sm)}.option-item{align-items:center;border-bottom:1px solid var(--color-border-light);display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs) 0}.option-item:last-child{border-bottom:none}.option-item-input,.option-item-value{flex:1 1;font-size:var(--font-size-sm)}.option-item-input{border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-family:var(--font-family);padding:2px var(--spacing-xs)}.option-item-btn{border:none;border-radius:var(--border-radius-sm);cursor:pointer;font-family:var(--font-family);font-size:12px;padding:2px 6px;transition:all var(--transition-fast)}.option-item-btn.edit-btn{background-color:var(--color-primary-light);color:var(--color-text-primary)}.option-item-btn.edit-btn:hover{background-color:var(--color-primary)}.option-item-btn.delete-btn{background-color:var(--color-danger-light);color:var(--color-danger)}.option-item-btn.delete-btn:hover{background-color:var(--color-danger);color:#fff}.option-item-btn.save-btn{background-color:var(--color-success-light);color:var(--color-success-dark)}.option-item-btn.cancel-btn{background-color:#e9ecef;color:#495057}.option-add-row{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.option-add-input{border:1px solid var(--color-border);border-radius:var(--border-radius-sm);flex:1 1;padding:4px var(--spacing-sm)}.option-add-btn,.option-add-input{font-family:var(--font-family);font-size:var(--font-size-sm)}.option-add-btn{background-color:var(--color-primary-light);border:1px solid var(--color-primary-dark);border-radius:var(--border-radius-sm);cursor:pointer;padding:4px 10px;transition:all var(--transition-fast)}.option-add-btn:hover{background-color:var(--color-primary)}.product-tags-panel{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-md);max-height:160px;overflow-y:auto;padding:var(--spacing-sm)}.product-tags-grid{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(5,1fr)}.product-tag-option{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;font-size:11px;padding:3px 6px;text-align:center;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.product-tag-option.selected{background-color:var(--color-primary);font-weight:var(--font-weight-medium)}.product-tag-option.selected,.product-tag-option:hover{border-color:var(--color-primary-dark)}.product-tag-chips{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-sm);display:flex;flex-wrap:wrap;gap:var(--spacing-xs);min-height:28px;padding:var(--spacing-xs)}.product-tag-chip{align-items:center;background-color:var(--color-primary);border:1px solid var(--color-primary-dark);border-radius:9999px;border-radius:var(--border-radius-pill,9999px);display:inline-flex;font-size:11px;font-weight:var(--font-weight-medium);gap:3px;padding:2px 8px}.product-tag-chip-remove{background:#0000;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:12px;line-height:1;padding:0}.product-tag-chip-remove:hover{color:var(--color-danger)}.volume-method-group{display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) 0}.volume-method-option{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.cost-source-group{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.cost-source-option{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.cost-card{border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);overflow:hidden}.cost-card-header{align-items:center;background:linear-gradient(135deg,#ffd54f26,#ffa00014);border-bottom:1px solid var(--color-border-light);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.cost-card-body{padding:var(--spacing-md)}.cost-add-btn{background-color:var(--color-background-light);border:1px dashed var(--color-primary-dark);border-radius:var(--border-radius-sm);color:var(--color-primary-dark);cursor:pointer;display:block;font-family:var(--font-family);font-size:var(--font-size-sm);padding:4px var(--spacing-sm);text-align:center;transition:all var(--transition-fast);width:100%}.cost-add-btn:hover:not(:disabled){background-color:var(--color-primary-light)}.cost-add-btn:disabled{cursor:not-allowed;opacity:.4}.cost-remove-btn{background-color:initial;border:1px solid var(--color-danger-light);border-radius:var(--border-radius-sm);color:var(--color-danger);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-xs);padding:2px 8px;transition:all var(--transition-fast)}.cost-remove-btn:hover{background-color:var(--color-danger);color:#fff}.hk-field-row{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-md)}.hk-computed-field{position:relative}.hk-computed-badge{background-color:var(--color-info-light);border-radius:var(--border-radius-sm);color:var(--color-info-dark);font-size:9px;font-weight:var(--font-weight-medium);padding:1px 4px;position:absolute;right:4px;top:-8px}.audit-table{border-collapse:collapse;font-size:var(--font-size-sm);width:100%}.audit-table th{background-color:var(--color-background);border-bottom:2px solid var(--color-border);font-weight:var(--font-weight-medium);text-align:left}.audit-table td,.audit-table th{padding:var(--spacing-sm) var(--spacing-md)}.audit-table td{border-bottom:1px solid var(--color-border-light);vertical-align:middle}.audit-table tbody tr:hover{background-color:var(--color-primary-light)}.marketing-radio-group{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-sm) 0}.marketing-radio-option{align-items:center;background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);transition:all var(--transition-fast)}.marketing-radio-option.selected,.marketing-radio-option:hover{background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}.marketing-radio-option.selected{font-weight:var(--font-weight-medium)}.product-view-mode .form-control{background-color:var(--color-background-dark);border-color:var(--color-border-light);cursor:default;pointer-events:none}.product-view-mode textarea.form-control{resize:none}.input-computed{background-color:#f0f7ff!important;border-color:var(--color-info-light)!important;color:var(--color-info-dark)!important;font-weight:var(--font-weight-medium)!important}@media (max-width:1200px){.products-data-table{font-size:var(--font-size-xs)}.products-data-table td,.products-data-table th{padding:var(--spacing-xs) var(--spacing-sm)}}@media (max-width:768px){.cascading-filters,.filter-row{flex-direction:column}.cascading-arrow{display:none}.action-bar{align-items:stretch;flex-direction:column}.products-table-container{overflow-x:auto}.products-data-table{min-width:1000px}.pagination-container{flex-direction:column;gap:var(--spacing-md)}.product-form-grid-3,.product-form-grid-4{grid-template-columns:1fr 1fr}.product-form-grid .span-2,.product-form-grid .span-3{grid-column:span 1}.hk-field-row{grid-template-columns:1fr 1fr}.product-tags-grid{grid-template-columns:repeat(3,1fr)}.batch-edit-bar{flex-direction:column;gap:var(--spacing-sm)}}.pd-page-header{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary-dark));box-shadow:var(--shadow-medium);padding:var(--spacing-md) var(--spacing-lg);position:sticky;top:0;z-index:100}.pd-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.pd-header-left{gap:var(--spacing-md)}.pd-back-btn,.pd-header-left{align-items:center;display:flex}.pd-back-btn{background:#fffc;border:none;border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-md);gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-normal)}.pd-back-btn:hover{background:#fff;box-shadow:var(--shadow-small)}.pd-page-title{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0}.pd-product-code{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.pd-header-actions{display:flex;gap:var(--spacing-sm)}.pd-container{margin:0 auto;max-width:1400px;padding:var(--spacing-lg)}.pd-tab-nav{background:var(--color-background-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);display:flex;margin-bottom:var(--spacing-lg);overflow-x:auto;padding:var(--spacing-xs)}.pd-tab-item{background:#0000;border:none;border-radius:var(--border-radius-sm);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-normal);white-space:nowrap}.pd-tab-item:hover{background-color:var(--color-primary-light);color:var(--color-text-primary)}.pd-tab-item.active{background-color:var(--color-primary);box-shadow:var(--shadow-small);color:var(--color-text-primary)}.pd-section-card{background-color:var(--color-background-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);margin-bottom:var(--spacing-lg);overflow:hidden;scroll-margin-top:200px}.pd-section-header{align-items:center;background:linear-gradient(135deg,#ffd54f4d,#ffa00033);border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.pd-section-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);gap:var(--spacing-sm);margin:0}.pd-section-icon{align-items:center;display:flex;height:24px;justify-content:center;width:24px}.pd-section-badge{border-radius:var(--border-radius-pill);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-xs) var(--spacing-sm)}.pd-badge-info{background-color:var(--color-info-light);color:var(--color-info-dark)}.hk-currency-badge{background-color:var(--color-background);color:var(--color-text-secondary);font-size:10px;font-weight:var(--font-weight-medium);line-height:1.4;padding:1px 4px}.pd-badge-restricted{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.pd-section-body{padding:var(--spacing-lg)}.pd-form-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg)}.pd-form-grid-2{grid-template-columns:repeat(2,1fr)}.pd-form-grid-3{grid-template-columns:repeat(3,1fr)}.pd-form-grid-4{grid-template-columns:repeat(4,1fr)}.pd-form-grid .full-width{grid-column:1/-1}.pd-required-mark{color:var(--color-danger);font-weight:var(--font-weight-bold)}.pd-tags-container{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);display:flex;flex-wrap:wrap;min-height:42px;padding:var(--spacing-sm)}.pd-tag,.pd-tags-container{align-items:center;gap:var(--spacing-xs)}.pd-tag{background-color:var(--color-primary-light);border-radius:var(--border-radius-pill);color:var(--color-text-primary);display:inline-flex;font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm)}.pd-tag-text{-webkit-user-select:none;user-select:none}.pd-tag-remove{border-radius:50%;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-xs);padding:2px}.pd-tag-remove:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.pd-image-upload-area{align-items:center;background-color:var(--color-background);border:2px dashed var(--color-border);border-radius:var(--border-radius-md);cursor:pointer;display:flex;justify-content:center;min-height:180px;padding:var(--spacing-lg);position:relative;text-align:center;transition:all var(--transition-normal)}.pd-image-upload-area:hover{background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}.pd-upload-placeholder{color:var(--color-text-secondary)}.pd-upload-placeholder-icon{font-size:48px;margin-bottom:var(--spacing-sm)}.pd-cbm-calculator{background-color:var(--color-background);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);overflow:hidden}.pd-cbm-table{display:grid;grid-template-columns:repeat(3,1fr)}.pd-cbm-header-cell{background-color:var(--color-background);border-right:1px solid var(--color-border-light);font-weight:var(--font-weight-medium);text-align:center}.pd-cbm-header-cell,.pd-cbm-input-cell{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-md)}.pd-cbm-input-cell,.pd-cbm-result-row{align-items:center;display:flex}.pd-cbm-result-row{background-color:var(--color-primary-light);gap:var(--spacing-lg);grid-column:span 3;justify-content:center;padding:var(--spacing-sm) var(--spacing-md)}.pd-cost-input-group{background-color:var(--color-background);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);overflow:hidden}.pd-cost-input-header{align-items:center;background:linear-gradient(135deg,#ffd54f26,#ffa00014);border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.pd-cost-input-title{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.pd-cost-radio{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.pd-status-selector{display:flex;gap:var(--spacing-sm);height:38px}.pd-status-option{align-items:center;background-color:var(--color-background-light);border:2px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;display:flex;flex:none;padding:var(--spacing-xs) var(--spacing-md);text-align:center;transition:all var(--transition-normal)}.pd-status-option:hover{border-color:var(--color-primary-dark)}.pd-status-option.active{background-color:var(--color-success-light);border-color:var(--color-success)}.pd-status-option.inactive{background-color:var(--color-danger-light);border-color:var(--color-danger)}.pd-status-option.pending{background-color:#fef3c7;background-color:var(--color-warning-light,#fef3c7);border-color:#f59e0b;border-color:var(--color-warning,#f59e0b)}.pd-checkbox-inline{align-items:center!important;cursor:pointer;display:flex!important;gap:var(--spacing-xs)}.pd-checkbox-inline input[type=checkbox]{cursor:pointer;flex-shrink:0;height:18px;margin-right:var(--spacing-xs);vertical-align:middle;width:18px}.pd-price-table{border-collapse:collapse;margin-top:var(--spacing-md);width:100%}.pd-price-table td,.pd-price-table th{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-sm) var(--spacing-md);text-align:left}.pd-price-table th{background-color:var(--color-background);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.pd-price-table tbody tr:hover{background-color:var(--color-primary-light)}.pd-alert-box{align-items:flex-start;background-color:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:var(--border-radius-sm);display:flex;gap:var(--spacing-sm);padding:var(--spacing-md)}.pd-alert-icon{font-size:var(--font-size-lg)}.pd-alert-content{flex:1 1}.pd-alert-title{font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-xs)}.pd-footer-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg) 0}@media (max-width:768px){.pd-header-content{flex-direction:column;gap:var(--spacing-md)}.pd-form-grid-2,.pd-form-grid-3,.pd-form-grid-4{grid-template-columns:1fr}.pd-tab-nav{flex-wrap:nowrap;overflow-x:auto}.pd-cbm-table{grid-template-columns:1fr}.pd-cbm-header-cell{border-right:none}.pd-cbm-result-row{flex-direction:column;gap:var(--spacing-sm);grid-column:span 1}}.quotes-page{background-color:var(--color-background);min-height:100vh}.container{margin:0 auto;max-width:1400px;padding:0 var(--spacing-lg) var(--spacing-xl)}.summary-cards{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-lg);padding-top:var(--spacing-lg)}.summary-card{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-left:4px solid var(--color-primary);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);padding:var(--spacing-md) var(--spacing-lg);transition:box-shadow var(--transition-normal)}.summary-card:hover{box-shadow:var(--shadow-medium)}.summary-card.card-draft{border-left-color:var(--color-text-secondary)}.summary-card.card-pending{border-left-color:var(--color-info)}.summary-card.card-approved{border-left-color:var(--color-success)}.summary-card-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.summary-card-value{color:var(--color-text-primary);font-size:var(--font-size-xxl);font-weight:var(--font-weight-bold)}.summary-card-sub{color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.filter-section{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.filter-section-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);margin:0 0 var(--spacing-md) 0}.filter-section-title:before{content:"🔍"}.filter-group label{margin-bottom:var(--spacing-xs)}.filter-group .form-control{font-size:var(--font-size-sm)}.filter-group-date{min-width:340px}.date-range-row{align-items:center;display:flex;gap:6px}.date-range-row .form-control{flex:1 1}.date-sep{color:var(--color-text-secondary);font-size:var(--font-size-sm);white-space:nowrap}.action-bar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.action-bar,.table-container{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small)}.table-container{overflow:hidden}.data-table{border-collapse:collapse;font-size:var(--font-size-sm);width:100%}.data-table thead{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary))}.data-table th{border-bottom:2px solid var(--color-primary-dark);color:var(--color-text-primary);font-weight:var(--font-weight-medium);line-height:1.3;padding:var(--spacing-sm) var(--spacing-md);text-align:left;white-space:nowrap}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background-color:#ffa00033}.data-table tbody tr{transition:background-color var(--transition-normal)}.data-table tbody tr:hover{background-color:var(--color-primary-light)}.data-table tbody tr:nth-child(2n){background-color:#fff9e680}.data-table td{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-sm) var(--spacing-md);vertical-align:middle}.quote-number{color:var(--color-info-dark);cursor:pointer;font-weight:var(--font-weight-bold);text-decoration:none}.quote-number:hover{color:var(--color-info);text-decoration:underline}.date-cell{white-space:nowrap}.date-main{color:var(--color-text-primary)}.date-sub{color:var(--color-text-secondary)}.company-badge,.date-sub{font-size:var(--font-size-xs)}.company-badge{align-items:center;border-radius:var(--border-radius-sm);display:inline-flex;font-weight:var(--font-weight-medium);padding:2px 6px}.company-huangji{background-color:#fff3e0;color:#e65100}.company-mingxuan{background-color:#e3f2fd;color:#1565c0}.company-faluo{background-color:#e8f5e9;color:#2e7d32}.status-badge{min-width:60px;text-align:center}.status-badge-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.status-badge-danger{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.status-badge-info{background-color:var(--color-info-light);color:var(--color-info-dark)}.export-badge{align-items:center;border-radius:var(--border-radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap}.export-badge.exported{background-color:#e8f5e9;color:#2e7d32}.row-action-btn{font-size:var(--font-size-sm)}.btn-view{background-color:var(--color-primary);color:var(--color-text-primary)}.btn-view:hover{background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.row-action-btn.btn-edit{background-color:#fff;border:1px solid #e0e0e0;color:#e65100}.row-action-btn.btn-edit:hover{background-color:#fff8e1;border-color:#ffcc02}.pagination-container{border-top:1px solid var(--color-border-light);flex-wrap:wrap;gap:var(--spacing-sm)}.pagination{flex-wrap:wrap}.quotes-loading{color:var(--color-text-secondary);font-size:var(--font-size-md);padding:var(--spacing-xxl);text-align:center}.quotes-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 20px;text-align:center}.quotes-empty-state .empty-icon{font-size:64px;margin-bottom:16px}.quotes-empty-state h2{color:var(--color-text-primary);font-size:24px;margin:0 0 8px}.quotes-empty-state p{color:var(--color-text-secondary);font-size:16px;margin:0}@media (max-width:1200px){.data-table{font-size:var(--font-size-xs)}.data-table td,.data-table th{padding:var(--spacing-xs) var(--spacing-sm)}}@media (max-width:768px){.summary-cards{grid-template-columns:1fr}.filter-row{flex-direction:column}.filter-group-date{min-width:0;min-width:auto}.action-bar,.date-range-row{flex-direction:column}.action-bar{align-items:stretch}.table-container{overflow-x:auto}.data-table{min-width:1100px}.pagination-container{align-items:flex-start;flex-direction:column}}.company-modal{max-width:560px}.company-modal .form-group-full{grid-column:1/-1}.company-modal-error{background-color:#fff3f3;border:1px solid var(--color-danger);border-radius:var(--border-radius-sm);color:var(--color-danger);font-size:14px;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.company-manage-btn{align-items:center;background:none;border:1px solid var(--color-border-light);border-radius:var(--border-radius-sm);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:14px;gap:4px;padding:4px 8px;transition:all var(--transition-normal);white-space:nowrap}.company-manage-btn:hover{background-color:var(--color-primary-light);border-color:var(--color-primary-dark);color:var(--color-primary-dark)}.company-list-section{margin-bottom:var(--spacing-md)}.company-list-section h4{color:var(--color-text-secondary);font-size:14px;margin:0 0 var(--spacing-sm) 0}.company-list-items{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.company-chip{align-items:center;background-color:var(--color-background);border:1px solid var(--color-border-light);border-radius:16px;cursor:pointer;display:inline-flex;font-size:13px;gap:4px;padding:4px 10px;transition:all var(--transition-normal)}.company-chip:hover{background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}.company-chip.is-default{opacity:.7}.company-chip-edit{color:var(--color-text-secondary);font-size:11px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.qc-page{background-color:var(--color-background);min-height:100vh}.qc-container{display:flex;flex-direction:column;gap:var(--spacing-lg);margin:0 auto;max-width:1400px;padding:var(--spacing-lg)}.qc-error-banner{background-color:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger-dark);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--spacing-sm) var(--spacing-md)}.qc-error-banner,.qc-section{border-radius:var(--border-radius-md)}.qc-section{background-color:var(--color-background-light);box-shadow:var(--shadow-small);margin-bottom:0;padding:var(--spacing-lg)}.qc-section-header{border-bottom:2px solid var(--color-primary);color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);justify-content:space-between;margin-bottom:var(--spacing-md);padding:0 0 var(--spacing-sm) 0}.qc-section-header,.qc-section-header-left,.qc-section-header-right{align-items:center;display:flex;gap:var(--spacing-sm)}.qc-section-number{align-items:center;background-color:var(--color-primary);border-radius:50%;color:var(--color-text-primary);display:inline-flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);height:28px;justify-content:center;width:28px}.qc-item-count{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal)}.qc-section-body{padding:0}.qc-form-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md)}.qc-grid-2{grid-template-columns:repeat(2,1fr)}.qc-grid-3{grid-template-columns:repeat(3,1fr)}.qc-grid-4{grid-template-columns:repeat(4,1fr)}.qc-grid-full{grid-column:1/-1}.qc-required{color:var(--color-danger);margin-left:2px}.qc-suggestions{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-medium);left:0;max-height:220px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 2px);z-index:50}.qc-suggestion-item{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:background-color var(--transition-fast)}.qc-suggestion-item:hover{background-color:var(--color-primary-light)}.qc-suggestion-name{color:var(--color-text-primary);flex:1 1;font-weight:var(--font-weight-medium)}.qc-suggestion-meta{background-color:var(--color-background);border:1px solid var(--color-border-light);color:var(--color-text-secondary);padding:1px 6px}.qc-selected-customer,.qc-suggestion-meta{border-radius:var(--border-radius-sm);font-size:var(--font-size-xs)}.qc-selected-customer{background-color:var(--color-success-light);color:var(--color-success-dark);display:inline-block;margin-top:var(--spacing-xs);padding:2px 8px}.qc-level-badge{align-items:center;background-color:var(--color-primary);border:1px solid var(--color-primary-dark);border-radius:50%;color:var(--color-text-primary);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);height:22px;justify-content:center;width:22px}.qc-rate-hint{background-color:var(--color-info-light);border-radius:var(--border-radius-sm);color:var(--color-info-dark);display:inline-block;font-size:var(--font-size-xs);margin-top:var(--spacing-xs);padding:2px 8px}.status-badge-draft{background-color:var(--color-background-dark);border:1px solid var(--color-border);border-radius:var(--border-radius-pill);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:2px 10px}.exchange-rate-display{align-items:center;background-color:var(--color-primary-light);border-radius:var(--border-radius-sm);display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md)}.exchange-rate-display .rate-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.exchange-rate-display .rate-value{color:var(--color-primary-dark);flex:1 1;font-weight:var(--font-weight-bold)}.exchange-rate-display .lock-icon{color:var(--color-success)}.qc-search-bar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.search-input-wrapper{flex:1 1;position:relative}.search-input-wrapper .search-icon{color:var(--color-text-secondary);left:var(--spacing-md);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input-wrapper .form-control{padding-left:36px}.qc-search-keyword{flex:2 1;min-width:220px}.qc-search-bar .form-group{flex:1 1;min-width:140px}.qc-search-actions{align-items:flex-end;display:flex;gap:var(--spacing-sm);padding-bottom:1px}.qc-search-results-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.qc-search-empty,.qc-search-results-header{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.qc-search-empty{padding:var(--spacing-xl);text-align:center}.qc-cost-source-tag{background-color:var(--color-primary-light);border:1px solid var(--color-primary-dark);border-radius:var(--border-radius-sm);color:var(--color-text-primary);display:inline-block;font-size:10px;font-weight:var(--font-weight-medium);padding:1px 6px}.qc-table-wrap{border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);max-height:320px;overflow-x:auto;overflow-y:auto}.qc-table{border-collapse:collapse;font-size:var(--font-size-sm);width:100%}.qc-table thead{position:sticky;top:0;z-index:4}.qc-table th,.qc-table thead{background-color:var(--color-primary-light)}.qc-table th{border-bottom:2px solid var(--color-primary);color:var(--color-text-primary);font-weight:var(--font-weight-medium);text-align:left;white-space:nowrap}.qc-table td,.qc-table th{padding:var(--spacing-sm) var(--spacing-md)}.qc-table td{border-bottom:1px solid var(--color-border-light);vertical-align:middle}.qc-items-table td{padding:var(--spacing-xs) var(--spacing-sm)}.qc-table tbody tr:hover{background-color:var(--color-background)}.qc-table tbody tr:last-child td{border-bottom:none}.qc-row-selected{background-color:#ffd54f33!important}.qc-row-modified{background-color:#ffa00012!important}.qc-items-table-wrap{border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);max-height:55vh;overflow-x:auto;overflow-y:auto}.qc-items-table{min-width:900px}.product-info-cell{align-items:flex-start;display:flex;flex-direction:row;gap:8px}.product-thumb{background:#fafafa;border:1px solid #e0e0e0;border-radius:var(--border-radius-sm);flex-shrink:0;height:48px;object-fit:contain;width:48px}.product-info-text{display:flex;flex-direction:column;gap:2px;min-width:0}.product-name-zh{color:var(--color-text-primary);font-size:var(--font-size-sm)}.product-name-en{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.no-image-badge{background-color:#f0f0f0;border:1px dashed #ccc;border-radius:var(--border-radius-sm);color:#999;flex-shrink:0;font-size:10px;font-weight:var(--font-weight-medium);height:48px;white-space:nowrap;width:48px}.btn-icon-sm,.no-image-badge{align-items:center;display:inline-flex;justify-content:center}.btn-icon-sm{background:none;border:1px solid #0000;border-radius:50%;cursor:pointer;font-size:var(--font-size-sm);height:28px;padding:0;transition:all var(--transition-fast);width:28px}.btn-icon-sm-outline{border-color:var(--color-primary-dark);color:var(--color-primary-dark)}.btn-icon-sm-outline:hover{background-color:var(--color-primary-light)}.btn-icon-sm-danger{border-color:var(--color-danger-light);color:var(--color-danger)}.btn-icon-sm-danger:hover{background-color:var(--color-danger);color:var(--color-text-inverse)}.qc-row-num{color:var(--color-text-secondary);font-size:var(--font-size-xs);text-align:center}.qc-spec{color:var(--color-text-primary)}.qc-pcs{color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-left:3px}.qc-tier-select{min-width:70px}.qc-eye-btn{background:none;border:none;cursor:pointer;font-size:13px;opacity:.6;padding:0 3px;transition:opacity var(--transition-fast);vertical-align:middle}.qc-eye-btn-active,.qc-eye-btn:hover{opacity:1}.qc-info-panel-row td{border-bottom:2px solid var(--color-primary)!important;padding:0!important}.qc-info-panel{background:linear-gradient(180deg,#fffdf5,#fff9e8);border:1px solid var(--color-primary);border-radius:var(--border-radius-md);margin:var(--spacing-xs) var(--spacing-md) var(--spacing-sm);max-width:680px;padding:var(--spacing-md) var(--spacing-lg)}.qc-info-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.qc-info-panel-title{color:var(--color-primary-dark);font-size:var(--font-size-md);font-weight:var(--font-weight-bold)}.qc-info-panel-close{align-items:center;background:none;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:16px;height:28px;justify-content:center;transition:all var(--transition-fast);width:28px}.qc-info-panel-close:hover{background-color:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.qc-info-section{margin-bottom:var(--spacing-xs)}.qc-info-section-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.qc-info-section-center{text-align:center}.qc-info-divider{border:none;border-top:1px solid var(--color-border-light);margin:var(--spacing-sm) 0}.qc-info-cost-table{border:1px solid var(--color-border-light);border-collapse:collapse;border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);overflow:hidden;width:100%}.qc-info-cost-table thead{background-color:var(--color-background)}.qc-info-cost-table th{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-align:left;white-space:nowrap}.qc-info-cost-table td,.qc-info-cost-table th{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-xs) var(--spacing-sm)}.qc-info-cost-table td{vertical-align:middle}.qc-info-cost-table tbody tr:last-child td{border-bottom:none}.qc-info-cost-active{background-color:#ffd54f26;font-weight:var(--font-weight-medium)}.qc-info-cost-price{color:var(--color-primary-dark);font-family:monospace;font-weight:var(--font-weight-bold)}.qc-info-volume-light{border-radius:50%;display:inline-block;height:12px;width:12px}.qc-info-light-yellow{background-color:#f5c842;box-shadow:0 0 4px #f5c84280}.qc-info-light-red{background-color:#ef4444;box-shadow:0 0 4px #ef444480}.qc-info-detail-block{background-color:var(--color-background);border-radius:var(--border-radius-sm);padding:var(--spacing-sm) var(--spacing-md)}.qc-info-detail-row{align-items:center;display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:2px 0}.qc-info-detail-label{color:var(--color-text-secondary)}.qc-info-detail-value{color:var(--color-primary-dark);font-weight:var(--font-weight-medium)}.qc-info-notes-block{background-color:var(--color-background);border-radius:var(--border-radius-sm);color:var(--color-text-primary);line-height:1.5;padding:var(--spacing-sm) var(--spacing-md);white-space:pre-wrap}.qc-info-notes-block,.qc-info-shipping-block{font-size:var(--font-size-sm)}.qc-info-shipping-row{margin-bottom:var(--spacing-xs)}.qc-info-shipping-ok{color:#16a34a}.qc-info-shipping-no,.qc-info-shipping-ok{display:block;font-weight:var(--font-weight-bold);margin-bottom:2px}.qc-info-shipping-no{color:#dc2626}.qc-info-shipping-countries{color:var(--color-text-secondary);padding-left:var(--spacing-md)}.qc-info-shipping-empty{color:var(--color-text-secondary);font-style:italic}.qc-btn-detail{background-color:initial;border:2px solid var(--color-primary-dark);color:var(--color-primary-dark);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin:var(--spacing-xs) auto 0;max-width:400px;padding:var(--spacing-sm) var(--spacing-xl);width:100%}.qc-btn-detail:hover:not(:disabled){background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.qc-price-cell{align-items:center;display:inline-flex;position:relative}.qc-price-input{background:#0000;border:1px solid #0000;border-radius:var(--border-radius-sm);color:var(--color-primary-dark);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);padding:var(--spacing-xs);transition:border-color var(--transition-fast);width:90px}.qc-price-input:focus,.qc-price-input:hover{background-color:#fff;border-color:var(--color-border-focus);outline:none}.qc-manual-price{color:var(--color-warning-dark)!important}.price-modified-dot{align-self:center;color:var(--color-danger);cursor:pointer;flex-shrink:0;font-size:16px;font-weight:700;line-height:1;pointer-events:auto}.qc-labeling-cell{display:flex;flex-direction:column;gap:3px}.qc-labeling-manual{max-width:80px}.qc-labeling-fee-hint{background-color:var(--color-info-light);border-radius:var(--border-radius-sm);color:var(--color-info-dark);font-size:var(--font-size-xs);padding:1px 6px;text-align:center}.qc-items-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between}.qc-items-controls-left{align-items:center}.qc-items-controls-left,.qc-items-controls-right,.qc-section3-controls{display:flex;gap:var(--spacing-sm)}.qc-section3-controls{align-items:center}.qc-inline-label{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap}.qc-markup-input{width:80px!important}.qc-items-empty{color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-xl);text-align:center}.qc-notes-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.qc-notes-header label{margin-bottom:0}.qc-notes-textarea{min-height:96px;resize:vertical}.footer-grid{grid-gap:var(--spacing-lg);align-items:stretch;display:grid;gap:var(--spacing-lg);grid-template-columns:2fr 1fr}.notes-left{display:flex;flex-direction:column}.notes-bottom-btn{align-self:flex-start;margin-top:var(--spacing-sm)}.contact-info-card{background-color:var(--color-background);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.contact-info-row{display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.contact-info-row:last-child{margin-bottom:0}.contact-info-label{color:var(--color-text-secondary)}.contact-info-value,.qc-btn{font-weight:var(--font-weight-medium)}.qc-btn{align-items:center;border:none;border-radius:var(--border-radius-sm);box-shadow:var(--shadow-small);cursor:pointer;display:inline-flex;font-family:var(--font-family);font-size:var(--font-size-md);gap:var(--spacing-sm);justify-content:center;line-height:1.5;padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-normal);white-space:nowrap}.qc-btn:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.qc-btn:active{transform:translateY(0)}.qc-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.65;transform:none;width:100%}.qc-btn-primary{background-color:var(--color-primary);border:1px solid var(--color-primary-dark);color:var(--color-text-primary)}.qc-btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.qc-btn-secondary{background-color:var(--color-secondary);border:1px solid var(--color-secondary-dark);color:var(--color-text-primary)}.qc-btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-dark);color:var(--color-text-primary)}.qc-btn-outline{background-color:initial;border:1px solid var(--color-primary-dark);color:var(--color-primary-dark)}.qc-btn-outline:hover:not(:disabled){background-color:var(--color-primary-light);color:var(--color-text-primary)}.qc-btn-success{background-color:var(--color-success);border:1px solid var(--color-success-dark);color:var(--color-text-inverse)}.qc-btn-success:hover:not(:disabled){background-color:var(--color-success-dark)}.qc-btn-save{background-color:var(--color-primary);border:1px solid var(--color-primary-dark);color:var(--color-text-primary)}.qc-btn-save:hover:not(:disabled){background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.qc-btn-danger-sm{background-color:initial;border:1px solid var(--color-danger-light);color:var(--color-danger);font-size:13px;padding:2px 7px}.qc-btn-danger-sm:hover:not(:disabled){background-color:var(--color-danger);color:var(--color-text-inverse)}.qc-btn-sm{font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-md)}.qc-bottom-bar{background-color:var(--color-background-light);border-radius:var(--border-radius-md);bottom:var(--spacing-md);box-shadow:var(--shadow-small);justify-content:space-between;margin-top:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);position:sticky}.action-bar-left,.qc-bottom-bar{align-items:center;display:flex;gap:var(--spacing-md)}.action-bar-left{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.action-bar-right{display:flex;gap:var(--spacing-sm)}.qc-btn-danger{background-color:var(--color-danger);border-color:var(--color-danger-dark);color:var(--color-text-inverse)}.qc-btn-danger:hover:not(:disabled){background-color:var(--color-danger-dark)}.qc-modal-overlay{align-items:center;background-color:#0006;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:var(--z-index-modal)}.qc-modal{background-color:var(--color-background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-large);max-width:90vw;min-width:320px;padding:var(--spacing-lg)}.qc-modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-md)}.qc-modal-body,.qc-modal-title{color:var(--color-text-primary)}.qc-modal-body{font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--spacing-lg)}.qc-modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.qc-product-drawer-overlay{background-color:#0006;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity var(--transition-normal),visibility var(--transition-normal);visibility:hidden;z-index:var(--z-index-modal)}.qc-product-drawer-overlay.active{opacity:1;visibility:visible}.qc-product-drawer{background-color:var(--color-background-light);box-shadow:var(--shadow-large);display:flex;flex-direction:column;height:100vh;overflow-y:auto;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform var(--transition-normal) ease;width:380px;z-index:calc(var(--z-index-modal) + 1)}.qc-product-drawer.active{transform:translateX(0)}.qc-product-drawer-header{align-items:center;background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));border-bottom:1px solid var(--color-border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.qc-product-drawer-header h3{color:var(--color-text-primary);font-size:var(--font-size-md);margin:0}.qc-product-drawer-close{background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-xl);line-height:1;padding:0;transition:opacity var(--transition-fast)}.qc-product-drawer-close:hover{opacity:.6}.qc-product-drawer-body{flex:1 1;overflow-y:auto;padding:var(--spacing-lg)}.qc-export-wrapper{position:relative}.qc-export-menu{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-md);bottom:calc(100% + 4px);box-shadow:var(--shadow-medium);min-width:140px;overflow:hidden;position:absolute;right:0;z-index:20}.qc-export-option{background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:block;font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:background-color var(--transition-fast);width:100%}.qc-export-option:hover{background-color:var(--color-primary-light)}.qc-export-option+.qc-export-option{border-top:1px solid var(--color-border-light)}@media (max-width:768px){.qc-grid-3,.qc-grid-4{grid-template-columns:1fr 1fr}.footer-grid,.qc-grid-2{grid-template-columns:1fr}.qc-items-controls,.qc-search-bar{flex-direction:column}.qc-items-controls{align-items:flex-start}.qc-bottom-bar{align-items:stretch;flex-direction:column}.action-bar-left{justify-content:center}.action-bar-right{flex-wrap:wrap;justify-content:flex-end}.qc-section3-controls{flex-wrap:wrap}}.qd-page{background-color:var(--color-background);min-height:100vh}.qd-container{display:flex;flex-direction:column;gap:var(--spacing-lg);margin:0 auto;max-width:1500px;padding:var(--spacing-lg)}.qd-loading{color:var(--color-text-secondary);font-size:var(--font-size-md);padding:var(--spacing-xxl);text-align:center}.qd-error-banner{background-color:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--border-radius-md);color:var(--color-danger-dark);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--spacing-sm) var(--spacing-md)}.qd-top-bar{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-small);justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.qd-top-bar,.qd-top-left{align-items:center;display:flex}.qd-top-left{gap:var(--spacing-md)}.qd-quote-number{color:var(--color-primary-dark);font-family:monospace;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.qd-top-right{align-items:center;display:flex;gap:var(--spacing-md)}.qd-last-edited{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.qd-status-badge{border-radius:12px;display:inline-block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:3px 12px;white-space:nowrap}.qd-status-draft{background-color:#e5e7eb;color:#374151}.qd-status-pending{background-color:#fef3c7;color:#92400e}.qd-status-approved{background-color:#d1fae5;color:#065f46}.qd-status-rejected{background-color:#fee2e2;color:#991b1b}.qd-section{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-small);overflow:hidden}.qd-section-header{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));border-bottom:2px solid var(--color-primary-dark);color:var(--color-text-primary);display:flex;font-size:var(--font-size-md);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg)}.qd-section-header,.qd-section-number{align-items:center;font-weight:var(--font-weight-bold)}.qd-section-number{background-color:var(--color-primary-dark);border-radius:50%;color:var(--color-text-inverse);display:inline-flex;flex-shrink:0;font-size:var(--font-size-sm);height:26px;justify-content:center;width:26px}.qd-item-count{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal)}.qd-section-body{padding:var(--spacing-lg)}.qd-info-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr)}.qd-grid-1{grid-template-columns:1fr}.qd-info-item{display:flex;flex-direction:column;gap:2px}.qd-info-label{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:.02em;text-transform:uppercase}.qd-info-label,.qd-info-value{font-weight:var(--font-weight-medium)}.qd-info-value{color:var(--color-text-primary);font-size:var(--font-size-sm)}.qd-mono{font-family:monospace}.qd-pre-wrap{line-height:1.5;white-space:pre-wrap}.qd-items-table-wrap{border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);overflow-x:auto}.qd-table{border-collapse:collapse;font-size:var(--font-size-sm);min-width:1100px;width:100%}.qd-table thead{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));position:sticky;top:0;z-index:4}.qd-table th{border-bottom:2px solid var(--color-primary-dark);color:var(--color-text-primary);font-weight:var(--font-weight-medium);padding:var(--spacing-sm) var(--spacing-md);text-align:left;white-space:nowrap}.qd-table td{border-bottom:1px solid var(--color-border-light);padding:var(--spacing-xs) var(--spacing-sm);vertical-align:middle}.qd-table tbody tr:hover{background-color:var(--color-primary-light)}.qd-table tbody tr:last-child td{border-bottom:none}.qd-row-num{text-align:center}.qd-pcs,.qd-row-num{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.qd-pcs{margin-left:3px}.qd-price{font-family:monospace;font-weight:var(--font-weight-medium)}.qd-manual-tag,.qd-price{color:var(--color-primary-dark)}.qd-manual-tag{background-color:#fff8e1;border:1px solid var(--color-primary-dark);border-radius:3px;display:inline-block;font-size:9px;font-weight:var(--font-weight-bold);margin-right:3px;padding:0 3px;vertical-align:middle}.qd-empty{color:var(--color-text-secondary);padding:var(--spacing-xl);text-align:center}.qd-btn,.qd-empty{font-size:var(--font-size-sm)}.qd-btn{align-items:center;border:1px solid #0000;border-radius:var(--border-radius-sm);cursor:pointer;display:inline-flex;font-family:var(--font-family);font-weight:var(--font-weight-medium);gap:var(--spacing-xs);justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast);white-space:nowrap}.qd-btn:disabled{cursor:not-allowed;opacity:.6}.qd-btn-secondary{background-color:var(--color-background);border-color:var(--color-border);color:var(--color-text-primary)}.qd-btn-secondary:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary-dark)}.qd-btn-primary{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-text-inverse)}.qd-btn-primary:hover:not(:disabled){background-color:#e65100;border-color:#e65100}.qd-btn-success{background-color:var(--color-success);border-color:var(--color-success-dark);color:var(--color-text-inverse)}.qd-btn-success:hover:not(:disabled){background-color:var(--color-success-dark)}.qd-btn-danger{background-color:var(--color-danger);border-color:var(--color-danger-dark);color:var(--color-text-inverse)}.qd-btn-danger:hover:not(:disabled){background-color:var(--color-danger-dark)}.qd-btn-info{background-color:var(--color-info);border-color:var(--color-info-dark);color:var(--color-text-inverse)}.qd-btn-info:hover:not(:disabled){background-color:var(--color-info-dark)}.qd-btn-approved-disabled,.qd-btn-pending-disabled{background-color:#fee2e2;border-color:#fecaca;color:#991b1b;cursor:not-allowed}.qd-bottom-bar{align-items:center;background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-small);display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-md) var(--spacing-lg)}.qd-export-wrapper{position:relative}.qd-export-menu{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-md);bottom:calc(100% + 4px);box-shadow:var(--shadow-medium);min-width:140px;overflow:hidden;position:absolute;right:0;z-index:20}.qd-export-option{background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:block;font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:background-color var(--transition-fast);width:100%}.qd-export-option:hover{background-color:var(--color-primary-light)}.qd-export-option+.qd-export-option{border-top:1px solid var(--color-border-light)}.qd-modal-overlay{align-items:center;background-color:#0006;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:var(--z-index-modal)}.qd-modal{background-color:var(--color-background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-large);max-width:90vw;min-width:320px;padding:var(--spacing-lg)}.qd-modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-md)}.qd-modal-body,.qd-modal-title{color:var(--color-text-primary)}.qd-modal-body{font-size:var(--font-size-sm);line-height:1.5;margin-bottom:var(--spacing-lg)}.qd-modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}@media (max-width:768px){.qd-info-grid{grid-template-columns:1fr 1fr}.qd-top-bar{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}.qd-bottom-bar{align-items:stretch;flex-direction:column}.qd-bottom-bar .qd-btn{width:100%}}.catalog-page{background-color:var(--color-background);font-family:var(--font-family);min-height:100vh}.catalog-container{margin:0 auto;max-width:1400px;padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-xl)}.catalog-filter-toolbar{background-color:#fff;border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.toolbar-section{margin-bottom:var(--spacing-md)}.toolbar-section:last-child{margin-bottom:0}.toolbar-section-title{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:1px;margin-bottom:var(--spacing-sm);text-transform:uppercase}.quick-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.quick-filter-btn{align-items:center;background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;display:inline-flex;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-normal)}.quick-filter-btn:hover{background-color:var(--color-primary-light);border-color:var(--color-primary)}.quick-filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary-dark)}.quick-filter-btn.highlight{background-color:var(--color-info-light);border-color:var(--color-info);color:var(--color-info-dark)}.quick-filter-btn.highlight.active{background-color:var(--color-info);color:#fff}.new-product-date-range{background:var(--color-background);border:1px solid var(--color-border-light);border-radius:var(--border-radius-sm);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.new-product-date-range .catalog-filter-label{color:var(--color-text-secondary);display:block;font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.date-range-inputs{align-items:center;display:flex;gap:var(--spacing-sm)}.date-input{border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);font-family:var(--font-family);padding:6px 10px}.date-input,.date-range-sep{font-size:var(--font-size-sm)}.date-range-sep{color:var(--color-text-secondary)}.date-range-error{color:var(--color-danger);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.catalog-filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.catalog-filter-group{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-xs);min-width:200px}.catalog-filter-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.multi-select-dropdown{position:relative;width:100%}.multi-select-trigger{align-items:center;background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;display:flex;font-family:var(--font-family);font-size:var(--font-size-sm);gap:var(--spacing-sm);justify-content:space-between;min-height:38px;padding:5px var(--spacing-md);width:100%}.multi-select-trigger:hover{border-color:var(--color-primary)}.multi-select-trigger .selected-tags{display:flex;flex:1 1;flex-wrap:wrap;gap:var(--spacing-xs)}.selected-tag{align-items:center;background-color:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);display:inline-flex;font-size:var(--font-size-xs);gap:3px;padding:2px 6px}.placeholder-text{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.multi-select-trigger .arrow{color:var(--color-text-secondary);flex-shrink:0;font-size:var(--font-size-xs)}.multi-select-menu{background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-medium);left:0;margin-top:2px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.multi-select-option{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:background-color .15s}.multi-select-option:hover{background-color:var(--color-background-light)}.multi-select-option input[type=checkbox]{accent-color:var(--color-primary-dark)}.tag-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tag-chip{background-color:var(--color-background);border:1px solid var(--color-border-light);border-radius:var(--border-radius-pill);cursor:pointer;font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-normal);-webkit-user-select:none;user-select:none}.tag-chip:hover{background-color:var(--color-primary-light);border-color:var(--color-primary)}.tag-chip.selected{background-color:var(--color-primary);border-color:var(--color-primary-dark)}.filter-action-row{border-top:1px solid var(--color-border-light);display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.catalog-action-toolbar{align-items:center;background-color:#fff;border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-small);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg)}.catalog-selection-info{align-items:center;display:flex;gap:var(--spacing-md)}.catalog-select-all{align-items:center;cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);-webkit-user-select:none;user-select:none}.catalog-checkbox{accent-color:var(--color-primary-dark);cursor:pointer;height:16px;width:16px}.catalog-selection-count{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.catalog-selection-count strong{color:var(--color-primary-dark);font-size:var(--font-size-lg)}.catalog-action-buttons{display:flex;gap:var(--spacing-sm)}.catalog-btn-remove{align-items:center;background-color:var(--color-danger);border:1px solid var(--color-danger-dark);border-radius:50%;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;height:22px;justify-content:center;line-height:1;opacity:.7;padding:0;transition:opacity .2s;width:22px}.catalog-btn-remove:hover{opacity:1}.tag-remove-btn{align-items:center;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:12px;line-height:1;padding:0}.tag-remove-btn:hover{color:var(--color-danger)}.catalog-table-container{background-color:#fff;border-radius:var(--border-radius-md);box-shadow:var(--shadow-medium);margin-bottom:var(--spacing-lg);overflow:hidden}.catalog-table{border-collapse:collapse;table-layout:auto;width:100%}.catalog-table thead{background-color:var(--color-primary-light)}.catalog-table th{border-bottom:2px solid var(--color-primary);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--spacing-sm) var(--spacing-md);text-align:left;white-space:nowrap}.catalog-table td.text-center,.catalog-table th.text-center{text-align:center}.catalog-table th.col-divider{background-color:var(--color-primary);padding:0;width:4px}.catalog-table th.col-checkbox{text-align:center;width:32px}.th-en{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-normal)}.catalog-table tbody tr{border-bottom:1px solid var(--color-border-light)}.catalog-table tbody tr:hover{background-color:var(--color-background-light)}.catalog-table tbody td.catalog-cell-selected,.catalog-table tbody tr.catalog-row-selected{background-color:var(--color-primary-light)}.catalog-table td{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);vertical-align:middle}.catalog-table td.col-divider{background-color:var(--color-background-dark);border-left:2px solid var(--color-border);padding:0;width:4px}.catalog-table td.col-checkbox{text-align:center;width:32px}.catalog-code{white-space:nowrap}.catalog-code,.product-name-sub{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.product-name-sub.missing{color:var(--color-danger);font-style:italic}.cost-cell{font-size:var(--font-size-xs);line-height:1.7;white-space:nowrap}.cost-source-badge{align-items:center;border-radius:var(--border-radius-sm);display:inline-flex;font-size:10px;font-weight:var(--font-weight-medium);margin-right:3px;padding:1px 5px}.cost-factory{background-color:#e8f5e9;color:#2e7d32}.cost-dealer1{background-color:#fff3e0;color:#e65100}.cost-dealer2{background-color:#e3f2fd;color:#1565c0}.cost-dealer3{background-color:#fce4ec;color:#c2185b}.cell-stack{display:flex;flex-direction:column;gap:2px}.cell-main{color:var(--color-text-primary);font-size:var(--font-size-sm)}.cell-sub,.remark-input{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.remark-input{background-color:initial;border:1px solid var(--color-border-light);border-radius:3px;font-family:var(--font-family);margin-top:2px;padding:2px 6px;width:100%}.remark-input:focus{background-color:#fff;border-color:var(--color-primary-dark);outline:none}.catalog-empty{color:var(--color-text-secondary);font-size:var(--font-size-md);padding:var(--spacing-xl)!important;text-align:center}.catalog-pagination{align-items:center;background-color:var(--color-background-light);border-top:1px solid var(--color-border-light);display:flex;gap:var(--spacing-xs);justify-content:center;padding:var(--spacing-md) var(--spacing-lg)}.catalog-page-btn{background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);min-width:36px;padding:var(--spacing-xs) var(--spacing-sm);text-align:center;transition:all var(--transition-normal)}.catalog-page-btn:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary)}.catalog-page-btn.active{background-color:var(--color-primary);border-color:var(--color-primary-dark);font-weight:var(--font-weight-medium)}.catalog-page-btn:disabled{cursor:not-allowed;opacity:.5}.catalog-page-ellipsis{color:var(--color-text-secondary);padding:0 var(--spacing-xs)}.batch-edit-hint{border:1px solid var(--color-info);border-radius:var(--border-radius-sm);color:var(--color-info-dark);font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm)}.batch-edit-hint,.catalog-table.batch-edit-active thead{background-color:var(--color-info-light)}.catalog-table.batch-edit-active thead th{border-bottom-color:var(--color-info)}.catalog-table tbody tr.catalog-row-batch:hover{background-color:var(--color-info-light)}.catalog-table td.col-remove-btn,.catalog-table th.col-remove-btn{padding:0;text-align:center;width:32px}.batch-edit-input{background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-xs);margin-top:3px;padding:4px var(--spacing-sm);width:100%}.batch-edit-input:focus{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-info-light);outline:none}.export-panel{background-color:#fff;border:1px solid var(--color-border-light);border-radius:var(--border-radius-md);box-shadow:var(--shadow-medium);padding:var(--spacing-lg)}.export-panel-header{align-items:center;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.export-panel-header h2{color:var(--color-text-primary);font-size:var(--font-size-lg);margin:0}.export-panel-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.export-options{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr}.export-option-group{background-color:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:var(--border-radius-sm);display:flex;flex-direction:column;padding:var(--spacing-md)}.export-top-section{margin-bottom:var(--spacing-sm);min-height:70px}.export-option-group h3{margin:0 0 var(--spacing-sm) 0}.export-option-group h3,.export-section-h3{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:1px;text-transform:uppercase}.export-section-h3{margin:var(--spacing-md) 0 var(--spacing-sm) 0!important}.export-input{background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);width:100%}.export-input:focus{border-color:var(--color-primary-dark);box-shadow:0 0 0 2px var(--color-primary-light);outline:none}.export-select{background-color:#fff;border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);width:100%}.export-select:focus{border-color:var(--color-primary-dark);outline:none}.contact-preview{background-color:var(--color-background);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.contact-row{display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.contact-row:last-child{margin-bottom:0}.contact-label{color:var(--color-text-secondary)}.contact-value{font-weight:var(--font-weight-medium)}.company-add-row{align-items:center;display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.company-input{flex:1 1}.company-tag-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.company-tag{align-items:center;background-color:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);display:inline-flex;font-size:var(--font-size-xs);gap:4px;padding:2px 8px}.export-actions{border-top:1px solid var(--color-border-light);display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-md)}@media (max-width:1024px){.export-options{grid-template-columns:1fr}.catalog-table{font-size:var(--font-size-xs)}.catalog-thumbnail{height:36px;width:36px}}@media (max-width:768px){.catalog-filter-row{flex-direction:column}.catalog-action-toolbar{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}.catalog-table-container{overflow-x:auto}}.tag-dropdown-wrap,.tag-dropdown-wrap .tag-dropdown{position:relative}.tag-dropdown-wrap .tag-dropdown-trigger{align-items:center;background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);cursor:pointer;display:flex;min-height:36px;padding:var(--spacing-xs) var(--spacing-sm);-webkit-user-select:none;user-select:none}.tag-dropdown-wrap .tag-dropdown-placeholder{color:var(--color-text-secondary);opacity:.6}.tag-dropdown-wrap .tag-dropdown-arrow{color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:transform var(--transition-fast)}.tag-dropdown-wrap .tag-dropdown.open .tag-dropdown-arrow{transform:rotate(180deg)}.tag-dropdown-wrap .tag-dropdown-menu{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:0 0 var(--border-radius-sm) var(--border-radius-sm);border-top:none;box-shadow:var(--shadow-small);display:grid;grid-template-columns:repeat(5,1fr);left:0;max-height:200px;overflow-y:auto;padding:var(--spacing-xs);position:absolute;right:0;top:100%;z-index:100;z-index:var(--z-index-dropdown,100)}.tag-dropdown-wrap .tag-dropdown-item{align-items:center;border-radius:var(--border-radius-sm);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);margin-bottom:0;padding:var(--spacing-xs) var(--spacing-sm);transition:background-color var(--transition-fast);white-space:nowrap}.tag-dropdown-wrap .tag-dropdown-item:hover{background-color:var(--color-primary-light)}.tag-dropdown-wrap .tag-dropdown-item input[type=checkbox]{accent-color:var(--color-primary-dark);cursor:pointer}.tag-dropdown-wrap .tag{align-items:center;background-color:var(--color-primary-light);border-radius:9999px;border-radius:var(--border-radius-pill,9999px);color:var(--color-text-primary);display:inline-flex;font-size:var(--font-size-sm);gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.tag-dropdown-wrap .tag-remove{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:14px;line-height:1;opacity:.6;padding:0}.tag-dropdown-wrap .tag-remove:hover{color:var(--color-danger);opacity:1}.company-select-row{align-items:center;display:flex;gap:var(--spacing-sm)}.company-select-row .export-select{flex:1 1}.company-tag-edit{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:13px;opacity:.6;padding:0 2px}.company-tag-edit:hover{color:var(--color-primary);opacity:1}.company-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.company-modal{background:#fff;border-radius:var(--border-radius-md);box-shadow:0 8px 32px #0000002e;max-height:90vh;max-width:95vw;overflow-y:auto;width:520px}.company-modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.company-modal-header h3{font-size:var(--font-size-lg);margin:0}.company-modal-close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:22px;line-height:1;padding:0 4px}.company-modal-close:hover{color:var(--color-danger)}.company-modal-body{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg)}.company-modal-field{display:flex;flex-direction:column;gap:4px}.company-modal-field label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600}.company-modal-field input{border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:var(--font-size-base);padding:8px 10px;transition:border-color .2s}.company-modal-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f626;outline:none}.company-modal-row{display:flex;gap:var(--spacing-md)}.company-modal-row .company-modal-field{flex:1 1}.company-modal-footer{border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding:var(--spacing-md) var(--spacing-lg)}.required-mark{color:var(--color-danger)}.append-panel{background-color:var(--color-background-light);border:1px dashed var(--color-primary);border-radius:var(--border-radius-md);display:none;margin-bottom:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg)}.append-panel.open{display:block}.append-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.append-panel-title{align-items:center;color:var(--color-primary-dark);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-xs)}.append-panel-close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:18px;line-height:1;opacity:.6}.append-panel-close:hover{opacity:1}.append-search-row{align-items:flex-start;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.append-search-wrap{flex:1 1;position:relative}.append-search-input{border:1px solid var(--color-border);border-radius:var(--border-radius-sm);box-sizing:border-box;font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;padding:var(--spacing-xs) var(--spacing-md);width:100%}.append-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.append-search-dropdown{background-color:var(--color-background-light);border:1px solid var(--color-border);border-radius:0 0 var(--border-radius-sm) var(--border-radius-sm);border-top:none;box-shadow:var(--shadow-medium);display:none;left:0;max-height:220px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.append-search-wrap.has-results .append-search-dropdown{display:block}.append-search-item{align-items:center;border-bottom:1px solid var(--color-border-light);cursor:pointer;display:flex;font-size:var(--font-size-sm);justify-content:space-between;padding:var(--spacing-xs) var(--spacing-md);transition:background-color var(--transition-fast)}.append-search-item:last-child{border-bottom:none}.append-search-item:hover{background-color:var(--color-primary-light)}.append-search-item-code{color:var(--color-text-secondary);font-family:monospace;font-size:11px;margin-right:var(--spacing-sm)}.append-search-item-name{flex:1 1}.append-search-item-add{background:none;border:1px solid var(--color-primary);border-radius:var(--border-radius-sm);color:var(--color-primary-dark);cursor:pointer;font-size:11px;padding:1px 6px;white-space:nowrap}.append-search-item-add:hover{background-color:var(--color-primary-light)}.append-search-item-add.already{border-color:var(--color-border-light);color:var(--color-text-secondary);cursor:default}.append-selected-area{align-items:center;background-color:#fafafa;border:1px solid var(--color-border-light);border-radius:var(--border-radius-sm);display:flex;flex-wrap:wrap;gap:var(--spacing-xs);min-height:32px;padding:var(--spacing-xs)}.append-selected-empty{color:var(--color-text-secondary);font-size:12px;padding:2px var(--spacing-xs)}.append-selected-chip{align-items:center;background-color:#e8f4fd;border:1px solid #90caf9;border-radius:999px;color:#1565c0;display:inline-flex;font-size:12px;gap:4px;padding:2px var(--spacing-sm)}.append-selected-chip-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:13px;line-height:1;opacity:.6;padding:0}.append-selected-chip-remove:hover{opacity:1}.append-panel-footer{align-items:center;border-top:1px solid var(--color-border-light);display:flex;justify-content:space-between;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.append-hint{color:var(--color-text-secondary);font-size:12px}:root{--color-primary:#ffd54f;--color-primary-light:#ffecb3;--color-primary-dark:#ffa000;--color-secondary:#f0c14b;--color-background:#fff9e6;--color-background-light:#fffbf0;--color-text-primary:#5d4037;--color-text-secondary:#8d6e63;--color-text-light:#6d4c41;--color-text-inverse:#fff;--color-success:#4caf50;--color-success-light:#a5d6a7;--color-success-dark:#2e7d32;--color-danger:#f44336;--color-danger-light:#ffcdd2;--color-danger-dark:#c62828;--color-warning:#ff9800;--color-warning-light:#ffe0b2;--color-warning-dark:#e65100;--color-info:#2196f3;--color-info-light:#bbdefb;--color-info-dark:#1976d2;--color-border:#d4b483;--color-border-light:#e6c9a3;--color-border-focus:#ffa000;--color-background-dark:#f5f0e8;--shadow-small:0 2px 5px #0000001a;--shadow-medium:0 4px 10px #0000001f;--shadow-large:0 10px 25px #00000026;--font-family:"Noto Sans TC",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--font-size-xs:11px;--font-size-sm:13px;--font-size-md:15px;--font-size-lg:17px;--font-size-xl:20px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-bold:700;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-xxl:48px;--border-radius-sm:4px;--border-radius-md:8px;--border-radius-lg:12px;--border-radius-pill:9999px;--transition-fast:0.2s;--transition-normal:0.3s;--z-index-modal:400}*{box-sizing:border-box}body{color:#5d4037;color:var(--color-text-primary);line-height:1.6;margin:0;padding:0}.btn,body{font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family)}.btn{align-items:center;border:none;border-radius:4px;border-radius:var(--border-radius-sm);cursor:pointer;display:inline-flex;font-size:15px;font-size:var(--font-size-md);font-weight:500;font-weight:var(--font-weight-medium);gap:4px;gap:var(--spacing-xs);justify-content:center;line-height:1.5;padding:8px 24px;padding:var(--spacing-sm) var(--spacing-lg);transition:all .3s;transition:all var(--transition-normal);white-space:nowrap}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-sm{font-size:13px;font-size:var(--font-size-sm);padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md)}.btn-primary{background-color:#ffd54f;background-color:var(--color-primary);border:1px solid #ffa000;border:1px solid var(--color-primary-dark);color:#5d4037;color:var(--color-text-primary)}.btn-primary:hover{background-color:#ffa000;background-color:var(--color-primary-dark)}.btn-primary:hover,.btn-success{color:#fff;color:var(--color-text-inverse)}.btn-success{background-color:#4caf50;background-color:var(--color-success);border:1px solid #2e7d32;border:1px solid var(--color-success-dark)}.btn-success:hover{background-color:#2e7d32;background-color:var(--color-success-dark)}.btn-danger,.btn-success:hover{color:#fff;color:var(--color-text-inverse)}.btn-danger{background-color:#f44336;background-color:var(--color-danger);border:1px solid #c62828;border:1px solid var(--color-danger-dark)}.btn-danger:hover{background-color:#c62828;background-color:var(--color-danger-dark);color:#fff;color:var(--color-text-inverse)}.btn-secondary{background-color:#f0c14b;background-color:var(--color-secondary);border:1px solid var(--color-secondary-dark)}.btn-secondary,.btn-secondary:hover{color:#5d4037;color:var(--color-text-primary)}.btn-secondary:hover{background-color:var(--color-secondary-dark)}.btn-outline{background-color:initial;border:1px solid #ffa000;border:1px solid var(--color-primary-dark);color:#ffa000;color:var(--color-primary-dark)}.btn-outline:hover{background-color:#ffecb3;background-color:var(--color-primary-light);color:#5d4037;color:var(--color-text-primary)}.btn-append-trigger{background-color:#e3f2fd;border:1px solid #90caf9;color:#1565c0}.btn-append-trigger:hover{background-color:#bbdefb}.form-group{display:flex;flex-direction:column}.form-group label{font-size:13px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);margin-bottom:4px;margin-bottom:var(--spacing-xs)}.form-control,.form-group label{color:#5d4037;color:var(--color-text-primary)}.form-control{background-color:#fffbf0;background-color:var(--color-background-light);border:2px solid #e6c9a3;border:2px solid var(--color-border-light);border-radius:4px;border-radius:var(--border-radius-sm);font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:14px;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:border-color .3s;transition:border-color var(--transition-normal);width:100%}.form-control:focus{border-color:#ffa000;border-color:var(--color-primary-dark);box-shadow:0 0 0 3px #ffa0001a;outline:none}.form-control:disabled{background-color:#f5f0e8;background-color:var(--color-background-dark);color:#8d6e63;color:var(--color-text-secondary);cursor:not-allowed}.form-control-sm{font-size:13px;font-size:var(--font-size-sm);padding:4px 8px;padding:4px var(--spacing-sm)}.status-badge{align-items:center;border-radius:4px;border-radius:var(--border-radius-sm);display:inline-flex;font-size:11px;font-size:var(--font-size-xs);font-weight:500;font-weight:var(--font-weight-medium);height:24px;justify-content:center;min-width:52px;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap}.row-actions{display:flex;gap:4px;gap:var(--spacing-xs);justify-content:center}.row-action-btn{border:none;border-radius:4px;border-radius:var(--border-radius-sm);cursor:pointer;font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:11px;font-size:var(--font-size-xs);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);transition:all .3s;transition:all var(--transition-normal);white-space:nowrap}.row-action-btn:hover{transform:translateY(-1px)}.btn-edit{background-color:#ffd54f;background-color:var(--color-primary);color:#5d4037;color:var(--color-text-primary)}.btn-edit:hover{background-color:#ffa000;background-color:var(--color-primary-dark);color:#fff;color:var(--color-text-inverse)}.select-checkbox{accent-color:#ffa000;accent-color:var(--color-primary-dark);cursor:pointer;height:18px;width:18px}.pagination-container{align-items:center;background-color:#fffbf0;background-color:var(--color-background-light);border:1px solid #e6c9a3;border:1px solid var(--color-border-light);border-radius:8px;border-radius:var(--border-radius-md);box-shadow:0 2px 5px #0000001a;box-shadow:var(--shadow-small);display:flex;justify-content:space-between;padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}.pagination-info{color:#8d6e63;color:var(--color-text-secondary);font-size:13px;font-size:var(--font-size-sm)}.pagination{display:flex;gap:4px;gap:var(--spacing-xs)}.page-btn{background-color:#fff9e6;background-color:var(--color-background);border:1px solid #d4b483;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--border-radius-sm);color:#5d4037;color:var(--color-text-primary);cursor:pointer;font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:13px;font-size:var(--font-size-sm);min-width:36px;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm);text-align:center;transition:all .3s;transition:all var(--transition-normal)}.page-btn:hover:not(:disabled){background-color:#ffecb3;background-color:var(--color-primary-light);border-color:#ffd54f;border-color:var(--color-primary)}.page-btn.active{background-color:#ffd54f;background-color:var(--color-primary);border-color:#ffa000;border-color:var(--color-primary-dark);font-weight:500;font-weight:var(--font-weight-medium)}.page-btn:disabled{cursor:not-allowed;opacity:.5}.page-size-selector{align-items:center;display:flex;font-size:13px;font-size:var(--font-size-sm);gap:8px;gap:var(--spacing-sm)}.page-size-selector select{background-color:#fff9e6;background-color:var(--color-background);border:1px solid #d4b483;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--border-radius-sm);font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;gap:var(--spacing-md);margin-bottom:16px;margin-bottom:var(--spacing-md)}.filter-row:last-child{margin-bottom:0}.filter-group{display:flex;flex:1 1;flex-direction:column;gap:4px;gap:var(--spacing-xs);min-width:180px}.filter-group label{color:#5d4037;color:var(--color-text-primary);font-size:13px;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);margin:0}.filter-group-wide{flex:2 1;min-width:280px}.action-group{align-items:center;display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm)}.action-group-label,.result-count{color:#8d6e63;color:var(--color-text-secondary);font-size:13px;font-size:var(--font-size-sm)}.result-count strong{color:#ffa000;color:var(--color-primary-dark);font-size:17px;font-size:var(--font-size-lg)}
/*# sourceMappingURL=main.220d7f3d.css.map*/