*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #3B82F6;--primary-hover: #2563EB;--success: #10B981;--warning: #F59E0B;--danger: #EF4444;--danger-hover: #DC2626;--bg: #F3F4F6;--surface: #FFFFFF;--text-primary: #1F2937;--text-secondary: #6B7280;--border: #E5E7EB;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--primary) 0%,#1D4ED8 100%);color:#fff;padding:1.5rem 1rem;box-shadow:var(--shadow-lg)}.header-content{max-width:1200px;margin:0 auto}.app-title{font-size:1.75rem;font-weight:700;display:flex;align-items:center;gap:.75rem}.app-subtitle{opacity:.9;margin-top:.25rem;font-size:.9rem}.header-actions{display:flex;align-items:center;gap:1rem;margin-top:1rem}.employee-info{font-size:.9rem;opacity:.9}.admin-badge{display:inline-flex;align-items:center;gap:.25rem;background:#fef3c7;color:#92400e;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.register-link{text-align:center;margin-top:1rem;font-size:.9rem;color:var(--text-secondary)}.register-link a{color:var(--primary);text-decoration:none}.register-link a:hover{text-decoration:underline}.employee-table{width:100%;border-collapse:collapse}.employee-table th,.employee-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.employee-table th{background:#f9fafb;font-weight:600;font-size:.875rem}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.main-content{flex:1;padding:1.5rem;max-width:1200px;margin:0 auto;width:100%}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);padding:1.25rem;border-radius:.75rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:48px;height:48px;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.stat-icon.blue{background:#dbeafe;color:var(--primary)}.stat-icon.green{background:#d1fae5;color:var(--success)}.stat-icon.orange{background:#fef3c7;color:var(--warning)}.stat-info h3{font-size:.875rem;color:var(--text-secondary);font-weight:500}.stat-info p{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.export-btn{margin-left:auto;padding:.375rem .75rem;background:var(--primary);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;cursor:pointer;display:flex;align-items:center;gap:.375rem;transition:background .2s}.export-btn:hover{background:var(--primary-hover)}.action-bar{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;align-items:center}.search-box{flex:1;min-width:250px;position:relative}.search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:.5rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg)}.btn-info{background:#06b6d4;color:#fff}.btn-info:hover{background:#0891b2}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.btn-sm{padding:.5rem .75rem;font-size:.875rem}.table-container{background:var(--surface);border-radius:.75rem;box-shadow:var(--shadow);overflow:hidden}.customer-table{width:100%;border-collapse:collapse}.customer-table th,.customer-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.customer-table th{background:#f9fafb;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.customer-table tr:hover{background:#f9fafb}.customer-table tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-badge.normal{background:#d1fae5;color:#065f46}.status-badge.expiring{background:#fef3c7;color:#92400e}.status-badge.expired{background:#fee2e2;color:#991b1b}.status-badge.ignored{background:#e5e7eb;color:#6b7280}.action-buttons{display:flex;gap:.5rem}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s;background:transparent}.icon-btn:hover{background:var(--bg)}.icon-btn.edit:hover{background:#dbeafe;color:var(--primary)}.icon-btn.delete:hover{background:#fee2e2;color:var(--danger)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state svg{width:80px;height:80px;margin-bottom:1.5rem;opacity:.5}.empty-state h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:.75rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.375rem;border:none;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s}.modal-close:hover{background:var(--bg);color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.75rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-group label .required{color:var(--danger);margin-left:.25rem}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.form-group .error-text{color:var(--danger);font-size:.8rem;margin-top:.375rem}.phones-container{display:flex;flex-direction:column;gap:.5rem}.phone-input-row{display:flex;gap:.5rem;align-items:center}.phone-input-row input{flex:1}.phone-remove-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:.5rem;background:var(--surface);color:var(--danger);cursor:pointer;transition:all .2s}.phone-remove-btn:hover{background:#fee2e2;border-color:var(--danger)}.phone-add-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border:1px dashed var(--border);border-radius:.5rem;background:transparent;color:var(--primary);font-size:.875rem;cursor:pointer;transition:all .2s}.phone-add-btn:hover{background:#eff6ff;border-color:var(--primary)}.product-price{color:var(--danger);font-weight:600;margin-left:auto;padding:2px 8px;background:#fef2f2;border-radius:4px;font-size:.85rem}.employee-badge{display:inline-block;padding:2px 8px;background:#8b5cf6;color:#fff;border-radius:4px;font-size:.75rem;font-weight:500;margin-left:8px}.product-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:.5rem;max-height:200px;overflow-y:auto;z-index:100;box-shadow:var(--shadow-lg);margin-top:4px}.product-suggestion-item{padding:10px 15px;cursor:pointer;transition:background .2s}.product-suggestion-item:hover{background:#f3f4f6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:.75rem}.toast{padding:1rem 1.25rem;border-radius:.5rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.75rem;animation:slideInRight .3s ease;max-width:350px}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.success{background:var(--success);color:#fff}.toast.warning{background:var(--warning);color:#fff}.toast.error{background:var(--danger);color:#fff}.toast.info{background:var(--primary);color:#fff}.confirm-dialog{text-align:center;padding:1.5rem}.confirm-dialog svg{width:64px;height:64px;color:var(--danger);margin-bottom:1rem}.confirm-dialog h3{font-size:1.25rem;margin-bottom:.5rem}.confirm-dialog p{color:var(--text-secondary);margin-bottom:1.5rem}.confirm-buttons{display:flex;justify-content:center;gap:1rem}.product-input-row{display:flex;gap:.5rem}.product-input-row input{flex:1}.product-list{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.product-item{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#eef2ff;border:1px solid #C7D2FE;border-radius:.375rem;font-size:.875rem;color:#4338ca}.product-item svg{color:#6366f1}.product-delete-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:transparent;color:#6366f1;cursor:pointer;border-radius:.25rem;margin-left:.25rem;padding:0;transition:all .2s}.product-delete-btn:hover{background:#c7d2fe;color:#4338ca}.no-products{margin-top:.75rem;padding:.75rem;background:#f9fafb;border:1px dashed var(--border);border-radius:.5rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.table-products{display:flex;flex-wrap:wrap;gap:.25rem}.product-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:#eef2ff;border-radius:9999px;font-size:.75rem;color:#4338ca;white-space:nowrap}.wechat-info{display:flex;flex-direction:column;gap:.25rem}.wechat-name{font-weight:500;color:var(--text-primary)}.wechat-id{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:#07c160}@media (max-width: 768px){.app-title{font-size:1.25rem}.main-content{padding:1rem}.customer-table{display:block;overflow-x:auto}.action-bar{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.product-input-row{flex-direction:column}.product-input-row .btn{justify-content:center}}.v-number-display,.v-number-tip{font-size:.75rem;color:var(--text-secondary);font-weight:400;margin-left:.5rem}.form-section-title{font-size:.95rem;font-weight:600;color:var(--text-primary);padding:.75rem 0 .5rem;margin-bottom:.5rem;border-top:1px solid var(--border);margin-top:.5rem}.form-section-title:first-of-type{border-top:none;margin-top:0;padding-top:0}.v-number{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#fef3c7;border:1px solid #FCD34D;border-radius:.375rem;font-size:.875rem;font-weight:600;color:#92400e}.icon-btn.repurchase{color:var(--success)}.icon-btn.repurchase:hover{background:#d1fae5;color:#065f46}.search-btn{padding:.75rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:0 .5rem .5rem 0;cursor:pointer;font-size:.95rem;transition:background .2s}.search-btn:hover{background:var(--primary-hover)}.search-box input{border-radius:.5rem 0 0 .5rem}.customer-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;padding:1rem}.customer-card{background:#fff;border:1px solid var(--border);border-radius:.5rem;padding:1rem;cursor:pointer;transition:all .2s}.customer-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}.customer-card.selected{border-color:var(--primary);background:#eff6ff}.customer-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.customer-card-header strong{flex:1}.customer-card-body{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.detail-panel{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.detail-panel-inner{background:#fff;border-radius:.75rem;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.detail-panel-header h3{font-size:1.25rem;font-weight:600}.detail-panel-body{flex:1;overflow-y:auto;padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.detail-row{display:flex;margin-bottom:.75rem;font-size:.95rem}.detail-label{color:var(--text-secondary);min-width:80px}.detail-value{color:var(--text-primary);flex:1}.purchase-record{background:#f9fafb;border:1px solid var(--border);border-radius:.5rem;padding:1rem;margin-bottom:1rem}.purchase-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-weight:600}.detail-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.detail-actions .btn{flex:1;justify-content:center}.no-data{color:var(--text-secondary);text-align:center;padding:2rem}
