:root{--primary-50:#e8eaf6;--primary-100:#c5cae9;--primary-200:#9fa8da;--primary-300:#7986cb;--primary-400:#5c6bc0;--primary-500:#3f51b5;--primary-600:#3949ab;--primary-700:#303f9f;--primary-800:#283593;--primary-900:#1a237e;--accent-100:#b2ebf2;--accent-200:#80deea;--accent-400:#26c6da;--accent-700:#0097a7;--surface:#fff;--surface-variant:#f5f5f5;--background:#fafafa;--text-primary:#000000de;--text-secondary:#0009;--text-disabled:#00000061;--text-on-primary:#fff;--success:#4caf50;--success-light:#e8f5e9;--warning:#ff9800;--warning-light:#fff3e0;--error:#f44336;--error-light:#ffebee;--info:#2196f3;--info-light:#e3f2fd;--shadow-1:0 1px 3px #0000001f,0 1px 2px #0000003d;--shadow-2:0 3px 6px #00000026,0 2px 4px #0000001f;--shadow-3:0 10px 20px #00000026,0 3px 6px #0000001a;--shadow-4:0 15px 25px #00000026,0 5px 10px #0000000d;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;color:var(--text-primary);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-weight:400;line-height:1.5}body{min-width:320px;min-height:100vh;margin:0;display:flex}h1{color:var(--text-primary);font-size:1.75rem;font-weight:600;line-height:1.2}h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;line-height:1.3}button,input,select,textarea{font-family:inherit}#root{width:100%}.form-group label{margin-bottom:var(--space-sm);color:var(--text-secondary);font-size:.875rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text-primary);border:1px solid #e0e0e0;padding:12px 16px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50);outline:none}.form-group input:disabled,.form-group select:disabled{background:var(--surface-variant);color:var(--text-disabled);cursor:not-allowed}.form-group .required{color:var(--error)}.form-group small{margin-top:var(--space-xs);color:var(--text-secondary);font-size:.75rem;display:block}.page-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.page-header h1{margin:0}.page-actions{gap:var(--space-sm);display:flex}.table-container{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);overflow:hidden}table{border-collapse:collapse;width:100%}thead th{text-align:left;padding:var(--space-md);background:var(--surface-variant);text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid #e0e0e0;font-size:.8125rem;font-weight:600}tbody td{padding:var(--space-md);border-bottom:1px solid #f0f0f0;font-size:.9375rem}tbody tr:hover{background:var(--surface-variant)}tbody tr:last-child td{border-bottom:none}.status-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:100px;align-items:center;padding:4px 12px;font-size:.75rem;font-weight:500;display:inline-flex}.status-badge.status-ready,.status-badge.status-active{background:var(--success-light);color:#2e7d32}.status-badge.status-sold{background:var(--warning-light);color:#e65100}.status-badge.status-used,.status-badge.status-completed{background:var(--info-light);color:#1565c0}.status-badge.status-refunded,.status-badge.status-inactive{background:var(--error-light);color:#c62828}.status-badge.status-suspended{background:var(--warning-light);color:#ef6c00}.filters{gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.filter-select{border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;border:1px solid #e0e0e0;min-width:180px;padding:10px 16px;font-size:.9375rem;transition:border-color .2s}.filter-select:focus{border-color:var(--primary-500);outline:none}.search-input{border-radius:var(--radius-sm);background:var(--surface);border:1px solid #e0e0e0;min-width:280px;padding:10px 16px;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-50);outline:none}.modal-overlay{z-index:1000;padding:var(--space-md);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-4);overflow-y:auto}.modal-content h2{margin:0 0 var(--space-lg)0;padding-bottom:var(--space-md);border-bottom:1px solid #f0f0f0}.modal-actions{gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid #f0f0f0;display:flex}.input-error{border-color:var(--error)!important}.error-message{color:var(--error);margin-top:var(--space-xs);align-items:center;gap:var(--space-xs);font-size:.75rem;display:flex}.toast-container{z-index:9999;flex-direction:column;gap:.75rem;max-width:400px;display:flex;position:fixed;top:1rem;right:1rem}.toast{cursor:pointer;background:#fff;border-left:4px solid;border-radius:.75rem;align-items:flex-start;gap:.75rem;padding:1rem;animation:.3s ease-out slideIn;display:flex;box-shadow:0 4px 12px #00000026}.toast:hover{box-shadow:0 6px 16px #0003}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.875rem;font-weight:700;display:flex}.toast-content{flex:1;min-width:0}.toast-title{color:#333;margin-bottom:.25rem;font-size:.95rem;font-weight:600}.toast-message{color:#666;font-size:.875rem;line-height:1.4}.toast-close{color:#999;cursor:pointer;opacity:.6;background:0 0;border:none;padding:0;font-size:1.25rem;line-height:1;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-success{border-left-color:#10b981}.toast-success .toast-icon{color:#10b981;background:#d1fae5}.toast-error{border-left-color:#ef4444}.toast-error .toast-icon{color:#ef4444;background:#fee2e2}.toast-warning{border-left-color:#f59e0b}.toast-warning .toast-icon{color:#f59e0b;background:#fef3c7}.toast-info{border-left-color:#3b82f6}.toast-info .toast-icon{color:#3b82f6;background:#dbeafe}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem;display:flex}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;text-transform:none;letter-spacing:.3px;border:none;font-family:inherit;font-weight:500;transition:all .15s;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:after{content:"";pointer-events:none;opacity:0;background-image:radial-gradient(circle,#ffffff4d 10%,#0000 10%);background-position:50%;background-repeat:no-repeat;width:100%;height:100%;transition:transform .4s,opacity .8s;position:absolute;top:0;left:0;transform:scale(10)}.btn:active:after{opacity:1;transition:all;transform:scale(0)}.btn-small{min-height:32px;padding:6px 16px;font-size:.8125rem}.btn-medium{min-height:40px;padding:10px 24px;font-size:.9375rem}.btn-large{min-height:48px;padding:14px 32px;font-size:1rem}.btn-full-width{width:100%}.btn-primary{background:var(--primary-600);color:var(--text-on-primary);box-shadow:var(--shadow-1)}.btn-primary:hover:not(:disabled){background:var(--primary-700);box-shadow:var(--shadow-2)}.btn-primary:active:not(:disabled){background:var(--primary-800)}.btn-secondary{color:var(--text-secondary);background:0 0;border:1px solid #e0e0e0}.btn-secondary:hover:not(:disabled){background:var(--surface-variant);border-color:#bdbdbd}.btn-secondary:active:not(:disabled){background:#eee}.btn-secondary:after{background-image:radial-gradient(circle,#0000001a 10%,#0000 10%)}.btn-danger{background:var(--error);color:var(--text-on-primary);box-shadow:var(--shadow-1)}.btn-danger:hover:not(:disabled){box-shadow:var(--shadow-2);background:#d32f2f}.btn-danger:active:not(:disabled){background:#c62828}.btn-success{background:var(--success);color:var(--text-on-primary);box-shadow:var(--shadow-1)}.btn-success:hover:not(:disabled){box-shadow:var(--shadow-2);background:#43a047}.btn-success:active:not(:disabled){background:#388e3c}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.btn-secondary .btn-spinner{border-color:#0000001a;border-top-color:var(--text-secondary)}.btn-icon{border-radius:50%;min-width:36px;min-height:36px;padding:8px}.btn-icon svg{fill:currentColor;width:20px;height:20px}.login-container{background:var(--primary-800);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:420px;box-shadow:var(--shadow-4)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-header h1{margin:0 0 var(--space-sm)0;color:var(--text-primary);font-size:1.75rem}.login-header p{color:var(--text-secondary);margin:0;font-size:.9375rem}.login-form{gap:var(--space-lg);flex-direction:column;display:flex}.login-form .form-group{margin-bottom:0}.login-form .form-group label{color:var(--text-primary);font-size:.875rem}.login-form .error-message{padding:var(--space-md);background:var(--error-light);border-radius:var(--radius-sm);color:var(--error);align-items:center;gap:var(--space-sm);border:1px solid #ffcdd2;font-size:.875rem;display:flex}.login-help{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid #f0f0f0}.demo-credentials{color:var(--text-secondary);text-align:center;margin:0;font-size:.8125rem;line-height:1.6}.demo-credentials strong{color:var(--text-primary)}.forgot-password-link{color:var(--primary-600);cursor:pointer;text-align:center;background:0 0;border:none;padding:0;font-size:.875rem;transition:color .15s}.forgot-password-link:hover{color:var(--primary-700);text-decoration:underline}.forgot-modal{text-align:center;max-width:400px}.forgot-modal h2{margin:0 0 var(--space-lg)0;color:var(--text-primary)}.forgot-modal-body{padding:var(--space-md)0}.forgot-icon{color:var(--primary-600);margin-bottom:var(--space-md)}.forgot-modal-body p{margin:0 0 var(--space-md)0;color:var(--text-secondary);line-height:1.6}.forgot-modal-body .contact-info{background:var(--surface-variant);padding:var(--space-md);border-radius:var(--radius-sm);font-size:.875rem}.forgot-modal-body .contact-info strong{color:var(--text-primary)}.forgot-modal .modal-actions{margin-top:var(--space-lg);justify-content:center}.forgot-icon.success{color:var(--success)}.forgot-modal-body .success-text{color:var(--success);font-size:1rem;font-weight:600}.forgot-modal-body .form-group{margin-bottom:var(--space-md);text-align:left}.forgot-modal-body .form-group input{text-align:center;width:100%}.forgot-modal-body .error-message{padding:var(--space-sm)var(--space-md);background:var(--error-light);border-radius:var(--radius-sm);color:var(--error);margin-bottom:var(--space-md);border:1px solid #ffcdd2;font-size:.875rem}.layout{background:var(--background);min-height:100vh;display:flex}.sidebar{background:var(--primary-800);width:260px;color:var(--text-on-primary);box-shadow:var(--shadow-2);flex-direction:column;display:flex}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid #ffffff1a}.sidebar-header h2{color:var(--text-on-primary);margin:0 0 4px;font-size:1.25rem;font-weight:600}.logo-subtitle{opacity:.7;margin:0;font-size:.8125rem}.sidebar-nav{padding:var(--space-md)0;flex:1;overflow-y:auto}.nav-item{width:100%;padding:12px var(--space-lg);color:#ffffffd9;text-align:left;cursor:pointer;align-items:center;gap:var(--space-md);background:0 0;border:none;border-left:3px solid #0000;font-size:.9375rem;transition:all .15s;display:flex;position:relative}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{border-left-color:var(--accent-400);color:#fff;background:#ffffff1f}.nav-item.active .nav-icon{color:var(--accent-400)}.nav-icon{opacity:.9;justify-content:center;align-items:center;width:20px;height:20px;font-size:1.125rem;display:flex}.nav-icon svg{fill:currentColor;width:20px;height:20px}.nav-label{font-weight:500}.sidebar-footer{padding:var(--space-md)var(--space-lg);background:#0000001a;border-top:1px solid #ffffff1a}.user-info{gap:var(--space-md);margin-bottom:var(--space-md);align-items:center;display:flex}.user-avatar{background:var(--primary-500);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:600;display:flex}.user-details{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.9375rem;font-weight:500;overflow:hidden}.user-role{opacity:.7;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.user-distributor{opacity:.7;margin-top:2px;font-size:.75rem}.sidebar-actions{gap:var(--space-sm);flex-direction:column;display:flex}.change-password-btn,.logout-btn{width:100%;padding:10px var(--space-md);color:#ffffffe6;border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-sm);background:0 0;border:1px solid #fff3;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.change-password-btn:hover,.logout-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.main-content{background:var(--background);flex:1;overflow-y:auto}.content-wrapper{padding:var(--space-xl);max-width:1400px;margin:0 auto}.layout .modal-overlay{z-index:1000;padding:var(--space-md);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.layout .modal-content{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);width:100%;max-width:400px;max-height:90vh;box-shadow:var(--shadow-4);overflow-y:auto}.layout .modal-content h2{margin:0 0 var(--space-lg)0;color:var(--text-primary);padding-bottom:var(--space-md);border-bottom:1px solid #f0f0f0;font-size:1.25rem}.layout .modal-actions{gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid #f0f0f0;display:flex}.layout .btn-primary{padding:12px var(--space-md);background:var(--primary-600);color:var(--text-on-primary);border-radius:var(--radius-sm);cursor:pointer;border:none;flex:1;font-size:.9375rem;font-weight:500;transition:background .15s}.layout .btn-primary:hover:not(:disabled){background:var(--primary-700)}.layout .btn-primary:disabled{opacity:.6;cursor:not-allowed}.layout .btn-secondary{padding:12px var(--space-md);background:var(--surface-variant);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;border:1px solid #e0e0e0;flex:1;font-size:.9375rem;font-weight:500;transition:background .15s}.layout .btn-secondary:hover:not(:disabled){background:#eee}.layout .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.dashboard h1{margin:0 0 var(--space-lg)0}.stats-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);align-items:center;gap:var(--space-md);box-shadow:var(--shadow-1);transition:box-shadow .2s,transform .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-2);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.stat-icon svg{fill:currentColor;width:28px;height:28px}.stat-icon.icon-distributors{background:var(--info-light);color:var(--info)}.stat-icon.icon-batches{background:var(--warning-light);color:var(--warning)}.stat-icon.icon-vouchers{background:var(--success-light);color:var(--success)}.stat-content{flex:1;min-width:0}.stat-value{color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.875rem}.recent-section{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);overflow:hidden}.recent-section h2{padding:var(--space-lg);border-bottom:1px solid #f0f0f0;margin:0;font-size:1.125rem}.recent-section .table-container{box-shadow:none;border-radius:0}.pagination{border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-top:16px;padding:16px 0;display:flex}.pagination-info{color:#6b7280;font-size:14px}.pagination-controls{align-items:center;gap:16px;display:flex}.items-per-page{color:#374151;align-items:center;gap:8px;font-size:14px;display:flex}.items-per-page label{font-weight:500}.items-per-page select{cursor:pointer;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 12px;font-size:14px;transition:all .2s}.items-per-page select:hover{border-color:#9ca3af}.items-per-page select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.pagination-buttons{align-items:center;gap:4px;display:flex}.pagination-btn{color:#374151;cursor:pointer;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;justify-content:center;align-items:center;min-width:36px;height:36px;padding:0 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.pagination-btn:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f9fafb}.pagination-btn.active{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.pagination-btn.active:hover{background-color:#2563eb;border-color:#2563eb}.pagination-ellipsis{color:#9ca3af;align-items:center;height:36px;padding:0 8px;font-size:14px;display:flex}@media (max-width:768px){.pagination{flex-direction:column;gap:12px}.pagination-controls{flex-direction:column;width:100%}.pagination-buttons{justify-content:center;width:100%}}.distributor-management h1{margin:0}.distributor-management .toolbar{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.distributor-management .toolbar .search-input{flex:0 400px}.distributor-management .toolbar .btn{white-space:nowrap;margin-left:auto;flex:none!important;width:auto!important}.distributor-management .sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background .15s}.distributor-management .sortable:hover{background:#eee}.distributor-management .action-btn{border:1px solid var(--primary-500);color:var(--primary-600);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:6px 12px;font-size:.8125rem;font-weight:500;transition:all .15s}.distributor-management .action-btn:hover{background:var(--primary-600);color:var(--text-on-primary)}.distributor-management .action-btn-primary{background:var(--primary-600);color:var(--text-on-primary);border-color:var(--primary-600)}.distributor-management .action-btn-primary:hover{background:var(--primary-700);border-color:var(--primary-700)}.action-cell{gap:var(--space-sm);flex-wrap:wrap;display:flex}.channel-button-group{gap:var(--space-sm);display:flex}.channel-btn{padding:10px var(--space-md);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);border:1px solid #e0e0e0;flex:1;font-size:.9375rem;font-weight:500;transition:all .15s}.channel-btn:hover{border-color:var(--primary-500);color:var(--primary-600)}.channel-btn.active{border-color:var(--primary-600);background:var(--primary-600);color:var(--text-on-primary)}.modal-subtitle{color:var(--text-secondary);margin:calc(-1*var(--space-md))0 var(--space-lg)0;font-size:.875rem}.input-disabled{background:var(--surface-variant)!important;color:var(--text-disabled)!important;cursor:not-allowed!important}.account-management h1{margin:0}.role-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:100px;align-items:center;padding:4px 12px;font-size:.75rem;font-weight:500;display:inline-flex}.role-badge.role-pm{background:var(--info-light);color:#1565c0}.role-badge.role-cskh{color:#7b1fa2;background:#f3e5f5}.delete-btn{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.delete-btn:hover{background:var(--error-light);color:var(--error)}.delete-btn svg{fill:currentColor;width:18px;height:18px}.password-input-group{gap:var(--space-sm);display:flex}.password-input-group input{flex:1}.random-btn{background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;width:44px;height:44px;color:var(--text-secondary);border:1px solid #e0e0e0;justify-content:center;align-items:center;transition:all .15s;display:flex}.random-btn:hover{border-color:var(--primary-500);background:var(--primary-50);color:var(--primary-600)}.random-btn svg{fill:currentColor;width:20px;height:20px}.credentials-modal{text-align:center}.credentials-modal h2{border-bottom:none!important;padding-bottom:0!important}.warning-text{color:#e65100;background:var(--warning-light);padding:var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-lg);justify-content:center;align-items:center;gap:var(--space-sm);font-size:.875rem;display:flex}.credentials-box{background:var(--surface-variant);border-radius:var(--radius-md);padding:var(--space-lg);text-align:left}.credential-item{margin-bottom:var(--space-md)}.credential-item:last-child{margin-bottom:0}.credential-item label{color:var(--text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;display:block}.credential-value{align-items:center;gap:var(--space-sm);display:flex}.credential-value span{color:var(--text-primary);background:var(--surface);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-sm);border:1px solid #e0e0e0;flex:1;font-family:Roboto Mono,monospace;font-size:1rem;font-weight:500}.copy-btn{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:background .15s;display:flex}.copy-btn:hover{background:var(--primary-50);color:var(--primary-600)}.copy-btn svg{fill:currentColor;width:18px;height:18px}.delete-modal{text-align:center}.delete-modal h2{color:var(--error)!important}.delete-warning{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1rem}.delete-note{color:var(--text-secondary);margin-bottom:0;font-size:.875rem}.create-batch h1{color:#333;margin:0 0 2rem}.preview-summary{background:#f8f9fa;border:2px dashed #667eea;border-radius:.5rem;margin:1.5rem 0;padding:1.5rem}.preview-summary h3{color:#667eea;margin:0 0 1rem;font-size:1.1rem}.summary-row{justify-content:space-between;margin-bottom:.75rem;font-size:1rem;display:flex}.summary-row strong{color:#333}.summary-row strong.highlight{color:#667eea;font-size:1.1rem}.batch-history{margin-top:3rem}.batch-history h2{color:#333;margin:0 0 1rem}code{background:#f5f5f5;border-radius:.25rem;padding:.25rem .5rem;font-family:Courier New,monospace;font-size:.9rem}.generate-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.85rem;transition:opacity .2s}.generate-btn:hover{opacity:.9}.create-batch .modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.create-batch .modal-content{background:#fff;border-radius:1rem;width:90%;max-width:500px;max-height:90vh;padding:2rem;overflow-y:auto}.create-batch .modal-content h2{color:#333;margin:0 0 1.5rem}.batch-info{background:#f8f9fa;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.batch-info p{color:#666;margin:.5rem 0}.batch-info p strong{color:#333}.create-batch .modal-actions{gap:1rem;margin-top:1.5rem;display:flex}.export-btn{color:#fff;cursor:pointer;background:#28a745;border:none;border-radius:.375rem;padding:.4rem .8rem;font-size:.85rem;font-weight:500;transition:all .2s}.export-btn:hover:not(:disabled){background:#218838}.export-btn:disabled{opacity:.6;cursor:not-allowed}.voucher-management h1{margin:0}.voucher-management .filters{gap:var(--space-md);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.filters-row{gap:var(--space-md);flex-wrap:wrap;align-items:center;display:flex}.date-filter{align-items:center;gap:var(--space-sm);display:flex}.date-filter label{color:var(--text-secondary);white-space:nowrap;font-size:.8125rem}.date-input{padding:10px var(--space-md);border-radius:var(--radius-sm);background:var(--surface);border:1px solid #e0e0e0;min-width:140px;font-size:.9375rem;transition:border-color .2s}.date-input:focus{border-color:var(--primary-500);outline:none}.fetch-limit{align-items:center;gap:var(--space-sm);display:flex}.fetch-limit label{color:var(--text-secondary);white-space:nowrap;font-size:.8125rem}.fetch-limit select{padding:10px var(--space-md);border-radius:var(--radius-sm);background:var(--surface);border:1px solid #e0e0e0;font-size:.9375rem}.clear-filter-btn{padding:10px var(--space-md);background:var(--surface);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;border:1px solid #e0e0e0;font-size:.8125rem;transition:all .15s}.clear-filter-btn:hover{background:var(--surface-variant);color:var(--text-primary);border-color:#bdbdbd}.results-info{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.875rem}.voucher-code-cell{align-items:center;gap:var(--space-sm);display:flex}.voucher-code{font-family:Roboto Mono,monospace;font-weight:500}.icon-btn{cursor:pointer;width:28px;height:28px;color:var(--text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:background .15s;display:flex}.icon-btn:hover{background:var(--surface-variant);color:var(--primary-600)}.icon-btn svg{width:16px;height:16px}.action-btn{border:1px solid var(--primary-500);color:var(--primary-600);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:6px 12px;font-size:.8125rem;font-weight:500;transition:all .15s}.action-btn:hover{background:var(--primary-600);color:var(--text-on-primary)}.detail-modal{width:90%;max-width:800px}.modal-header{padding:var(--space-md)var(--space-lg);background:var(--surface-variant);border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;display:flex}.modal-header h2{margin:0;font-size:1.125rem}.modal-close{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;transition:background .15s;display:flex}.modal-close:hover{color:var(--text-primary);background:#eee}.modal-body{padding:var(--space-lg);overflow-y:auto}.detail-section{margin-bottom:var(--space-xl)}.detail-section:last-of-type{margin-bottom:0}.detail-section h3{margin:0 0 var(--space-md)0;color:var(--text-primary);padding-bottom:var(--space-sm);border-bottom:2px solid var(--primary-500);font-size:.9375rem;display:inline-block}.detail-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.detail-item{gap:var(--space-xs);flex-direction:column;display:flex}.detail-item label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.detail-item span{color:var(--text-primary);font-size:.9375rem;font-weight:500}.voucher-code-value{background:var(--surface-variant);padding:var(--space-xs)var(--space-sm);border-radius:var(--radius-sm);font-family:Roboto Mono,monospace;display:inline-block}.timeline{padding-left:var(--space-xl);position:relative}.timeline:before{content:"";left:var(--space-sm);background:#e0e0e0;width:2px;position:absolute;top:0;bottom:0}.timeline-item{padding-bottom:var(--space-lg);position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-marker{background:var(--primary-500);border:2px solid var(--surface);width:12px;height:12px;box-shadow:0 0 0 2px var(--primary-500);border-radius:50%;position:absolute;top:4px;left:-26px}.timeline-content{padding-left:var(--space-sm)}.timeline-label{color:var(--text-primary);margin-bottom:var(--space-xs);font-weight:600}.timeline-date{color:var(--text-secondary);font-size:.8125rem}.timeline-detail{color:var(--text-disabled);margin-top:var(--space-xs);font-size:.8125rem}.timeline-loading{text-align:center;padding:var(--space-md);color:var(--text-secondary)}.logs-loading{text-align:center;padding:var(--space-xl);color:var(--text-secondary)}.logs-table{border-collapse:collapse;width:100%;font-size:.8125rem}.logs-table th,.logs-table td{padding:var(--space-sm)var(--space-md);text-align:left;border-bottom:1px solid #f0f0f0}.logs-table th{background:var(--surface-variant);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:.75rem;font-weight:600}.logs-table tbody tr:hover{background:var(--surface-variant)}.no-logs{text-align:center;color:var(--text-secondary);padding:var(--space-md);margin:0}@media (max-width:768px){.filters-row{flex-direction:column;align-items:stretch}.search-input,.filter-select{width:100%;max-width:none}.detail-grid{grid-template-columns:1fr}.detail-modal{width:95%}}.assign-order h1{color:#333;margin:0 0 2rem}.form-group input,.form-group select{border:2px solid #e0e0e0;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input.input-error{border-color:#dc3545}.error-message{color:#dc3545;margin-top:.5rem;font-size:.85rem;display:block}.note-box{color:#856404;background:#fff3cd;border-radius:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem;line-height:1.5}.refund h1{color:#333;margin:0 0 2rem}.search-section{margin-bottom:2rem}.search-form{max-width:600px}.search-input-group{gap:.75rem;display:flex}.search-input-group input{border:2px solid #e0e0e0;border-radius:.5rem;flex:1;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.search-input-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.search-input-group input.input-error{border-color:#dc3545}.search-error{color:#dc3545;margin-top:.5rem;font-size:.875rem}.result-section{margin-bottom:2rem}.result-section .table-container{background:#fff;border-radius:.75rem;max-width:700px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.result-section table{border-collapse:collapse;width:100%}.result-section th,.result-section td{text-align:left;border-bottom:1px solid #e0e0e0;padding:1rem}.result-section th{color:#333;background:#f8f9fa;font-weight:600}.result-section td code{background:#f5f5f5;border-radius:.25rem;padding:.25rem .5rem;font-family:Courier New,monospace;font-size:.9rem}.info-box{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:.5rem;max-width:600px;padding:1.5rem}.info-box.warning{background:#fff3cd;border-left-color:#ffc107}.info-box h3{color:#1565c0;margin:0 0 1rem;font-size:1rem}.info-box.warning h3{color:#856404}.info-box ul{margin:0;padding-left:1.5rem}.info-box li{color:#0d47a1;margin-bottom:.5rem;font-size:.9rem}.info-box.warning li{color:#856404}.info-box li:last-child{margin-bottom:0}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:1rem;width:90%;max-width:450px;max-height:90vh;padding:2rem;overflow-y:auto}.modal-content h2{color:#333;margin:0 0 1.5rem;font-size:1.25rem}.voucher-info{background:#f8f9fa;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.info-row{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.info-row:not(:last-child){border-bottom:1px solid #e0e0e0}.info-row label{color:#666;font-size:.9rem}.info-row span{color:#333;font-weight:600}.info-row span.code{background:#e3f2fd;border-radius:.25rem;padding:.25rem .5rem;font-family:Courier New,monospace;font-size:.85rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;margin-bottom:.5rem;font-weight:500;display:block}.required{color:#dc3545}.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.error-box{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb;border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.warning-note{color:#856404;background:#fff3cd;border-radius:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem;line-height:1.5}.modal-actions{gap:1rem;display:flex}.modal-actions button{flex:1}@media (max-width:768px){.search-input-group{flex-direction:column}.modal-content{width:95%;padding:1.5rem}.modal-actions{flex-direction:column}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{min-height:100vh}
