.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-dark);padding:20px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(232,104,53,.15) 0%,transparent 70%);pointer-events:none}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:450px;padding:48px;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.login-form{margin-bottom:24px}.login-button{width:100%;padding:14px 24px;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;transition:all .3s ease;margin-top:8px;box-shadow:0 4px 12px #e868354d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #e8683566}.login-button:active:not(:disabled){transform:translateY(0)}.login-footer{text-align:center;padding-top:24px;border-top:1px solid var(--border);margin-top:24px}.login-footer p{color:var(--text-secondary);font-size:14px}.signup-link{color:var(--primary-color);text-decoration:none;font-weight:600;transition:color .2s}.signup-link:hover{color:var(--primary-light);text-decoration:underline}.signup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-dark);padding:40px 20px;position:relative;overflow:hidden}.signup-container:before{content:"";position:absolute;bottom:-50%;left:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(232,104,53,.12) 0%,transparent 70%);pointer-events:none}.signup-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:520px;padding:48px;position:relative;z-index:1}.signup-header{text-align:center;margin-bottom:36px}.signup-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:8px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.signup-header p{color:var(--text-secondary);font-size:15px}.signup-form{margin-bottom:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.form-group label .required{color:var(--error-color);margin-left:2px}.form-group input{width:100%;padding:14px 18px;background-color:var(--surface-elevated);border:1px solid var(--border);border-radius:10px;font-size:15px;color:var(--text-primary);transition:all .3s ease}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #e868351a;background-color:var(--surface)}.form-group input:disabled{background-color:var(--background-alt);cursor:not-allowed;opacity:.6}.password-strength{margin-top:8px;font-size:12px}.strength-bar{height:4px;background-color:var(--border);border-radius:2px;margin-bottom:4px;overflow:hidden}.strength-bar-fill{height:100%;transition:width .3s ease,background-color .3s ease}.strength-weak{background-color:var(--error-color)}.strength-medium{background-color:var(--warning-color)}.strength-strong{background-color:var(--success-color)}.strength-text{color:var(--text-muted)}.signup-button{width:100%;padding:14px 24px;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;transition:all .3s ease;margin-top:8px;box-shadow:0 4px 12px #e868354d}.signup-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #e8683566}.signup-button:active:not(:disabled){transform:translateY(0)}.signup-footer{text-align:center;padding-top:24px;border-top:1px solid var(--border);margin-top:24px}.signup-footer p{color:var(--text-secondary);font-size:14px}.login-link{color:var(--primary-color);text-decoration:none;font-weight:600;transition:color .2s}.login-link:hover{color:var(--primary-light);text-decoration:underline}@media(max-width:768px){.signup-card{padding:32px 24px}.signup-header h1{font-size:26px}.form-row{grid-template-columns:1fr;gap:0}}.dashboard-container{min-height:100vh;background-color:var(--background)}.dashboard-header{background:var(--surface);border-bottom:1px solid var(--border);padding:20px 40px;box-shadow:var(--shadow-sm)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.business-info{display:flex;flex-direction:column;gap:2px}.company-name{font-size:18px;font-weight:600;color:var(--primary-color);margin:0}.business-id{font-size:13px;color:var(--text-secondary);margin:0}.header-actions{display:flex;gap:12px}.upload-button{padding:12px 24px;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #e868354d}.upload-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e8683566}.templates-button,.admin-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.templates-button:hover,.admin-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.settings-button{padding:12px 24px;background-color:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:10px;font-size:14px;font-weight:500;transition:all .3s ease}.settings-button:hover{background-color:var(--background-alt);border-color:var(--primary-color);color:var(--primary-color)}.logout-button{padding:12px 24px;background-color:var(--surface-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:10px;font-size:14px;font-weight:500;transition:all .3s ease}.logout-button:hover{background-color:var(--background-alt);border-color:var(--border-light);color:var(--text-primary)}.dashboard-main{max-width:1400px;margin:0 auto;padding:32px 40px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm)}.stat-card h3{font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:36px;font-weight:700;color:var(--primary-color)}.invoices-section{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-size:20px;font-weight:600;color:var(--text-primary)}.refresh-button{padding:10px 20px;background-color:var(--surface-elevated);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:8px;font-size:14px;font-weight:500;transition:all .3s ease}.refresh-button:hover:not(:disabled){background-color:var(--primary-color);color:#fff}.loading-state,.empty-state{text-align:center;padding:60px 20px}.empty-state p{color:var(--text-secondary);font-size:16px;margin-bottom:20px}.primary-button{padding:14px 28px;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #e868354d}.primary-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #e8683566}.invoices-table-container{overflow-x:auto}.invoices-table{width:100%;border-collapse:collapse}.invoices-table thead{background-color:var(--background);border-bottom:2px solid var(--border)}.invoices-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.invoices-table td{padding:16px;border-bottom:1px solid var(--border);font-size:14px}.invoices-table tbody tr:hover{background-color:var(--background)}.irn-cell{font-family:monospace;font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.status-success{background-color:#d1fae5;color:#065f46}.status-pending{background-color:#fef3c7;color:#92400e}.status-error{background-color:#fee2e2;color:#991b1b}.status-default{background-color:#f1f5f9;color:var(--text-secondary)}.status-select{padding:4px 20px 4px 8px;border-radius:12px;font-size:12px;font-weight:600;border:1px solid transparent;cursor:pointer;outline:none;transition:all .2s;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 4px center;background-size:12px}.status-select:hover{filter:brightness(.95);border-color:#0000001a}.status-select.status-success{background-color:#d1fae5;color:#065f46}.status-select.status-pending{background-color:#fef3c7;color:#92400e}.status-select.status-error{background-color:#fee2e2;color:#991b1b}.status-select.status-default{background-color:#f1f5f9;color:var(--text-secondary)}.action-button{padding:6px 12px;background-color:transparent;color:var(--primary-color);border:1px solid var(--border);border-radius:6px;font-size:13px;font-weight:500;transition:all .2s}.action-button:hover{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.header-controls{display:flex;align-items:center;gap:16px}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.filter-select{padding:8px 16px;background-color:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease}.filter-select:hover:not(:disabled){border-color:var(--primary-color)}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #e868351a}.filter-select:disabled{opacity:.6;cursor:not-allowed}.sort-order-button{padding:10px 18px;background-color:var(--surface-elevated);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:4px}.sort-order-button:hover:not(:disabled){background-color:var(--primary-color);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #e8683533}.sort-order-button:disabled{opacity:.6;cursor:not-allowed}.pagination-container{display:flex;align-items:center;justify-content:space-between;gap:16px}.pagination-top{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.pagination-bottom{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.pagination-button{padding:12px 24px;background-color:var(--surface-elevated);color:var(--primary-color);border:2px solid var(--primary-color);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px;display:flex;align-items:center;justify-content:center;gap:8px}.pagination-button:hover:not(:disabled){background-color:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #e868354d}.pagination-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #e8683533}.pagination-button:disabled{opacity:.4;cursor:not-allowed;background-color:var(--background);border-color:var(--border);color:var(--text-secondary)}.pagination-info{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:14px;color:var(--text-primary);font-weight:500}.pagination-details{font-size:12px;color:var(--text-secondary);font-weight:400}.pagination-pages{display:flex;align-items:center;gap:6px}.pagination-number{min-width:40px;height:40px;padding:8px;background-color:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.pagination-number:hover:not(:disabled):not(.active){background-color:var(--background);border-color:var(--primary-color);color:var(--primary-color)}.pagination-number.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:0 2px 8px #e868354d;font-weight:600}.pagination-number:disabled{opacity:.4;cursor:not-allowed}.pagination-ellipsis{padding:8px 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;user-select:none}@media(max-width:768px){.dashboard-header{padding:16px 20px}.header-content{flex-direction:column;align-items:flex-start;gap:16px}.dashboard-main{padding:20px}.invoices-table{font-size:13px}.invoices-table th,.invoices-table td{padding:10px 12px}.pagination-container{flex-direction:column;gap:12px}.pagination-top,.pagination-bottom{margin:16px 0;padding:16px 0}.pagination-button{min-width:100px;padding:10px 16px;font-size:13px}.pagination-info{order:-1;margin-bottom:8px}.pagination-pages{flex-wrap:wrap;justify-content:center;order:1}.pagination-number{min-width:36px;height:36px;padding:6px;font-size:13px}.header-controls{flex-direction:column;align-items:flex-start;width:100%}.filter-group{width:100%}.filter-select{flex:1}.sort-order-button,.refresh-button{width:100%}}.filter-input{padding:8px 12px;background-color:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;transition:all .2s ease;min-width:150px}.filter-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #e868351a}.filter-input:disabled{opacity:.6;cursor:not-allowed}.filter-input::placeholder{color:var(--text-muted)}.date-filters-row{display:flex;flex-wrap:wrap;align-items:center;gap:24px;padding:16px;background-color:var(--background);border-radius:8px;margin-bottom:20px}.date-filter-group{display:flex;align-items:center;gap:10px}.date-filter-group label{font-size:14px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.date-range{display:flex;align-items:center;gap:8px}.date-range span{color:var(--text-muted);font-size:13px}.date-input{padding:8px 12px;background-color:var(--surface);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;transition:all .2s ease}.date-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #e868351a}.date-input:disabled{opacity:.6;cursor:not-allowed}.clear-filters-button{padding:8px 16px;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-filters-button:hover:not(:disabled){background-color:var(--surface-elevated);color:var(--error-color);border-color:var(--error-color)}.clear-filters-button:disabled{opacity:.6;cursor:not-allowed}.limit-selector{display:flex;align-items:center;gap:8px;margin-left:16px}.limit-selector label{font-size:14px;font-weight:500;color:var(--text-secondary)}.limit-select{padding:8px 12px;background-color:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease}.limit-select:hover:not(:disabled){border-color:var(--primary-color)}.limit-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #e868351a}.limit-select:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.date-filters-row{flex-direction:column;align-items:flex-start;gap:16px}.date-filter-group{flex-direction:column;align-items:flex-start;width:100%}.date-range{width:100%}.date-input{flex:1;min-width:0}.limit-selector{margin-left:0;width:100%;justify-content:center;margin-top:8px}}.bulk-actions-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#e868351a,#e868350d);border:1px solid rgba(232,104,53,.3);border-radius:8px;margin-bottom:16px}.selected-count{font-size:14px;font-weight:600;color:var(--primary-color)}.bulk-action-buttons{display:flex;align-items:center;gap:12px}.bulk-action-buttons label{font-size:14px;font-weight:500;color:var(--text-secondary)}.bulk-status-select{padding:8px 16px;background-color:var(--surface);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease}.bulk-status-select:hover:not(:disabled){border-color:var(--primary-color)}.bulk-status-select:disabled{opacity:.6;cursor:not-allowed}.clear-selection-button{padding:8px 16px;background-color:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-selection-button:hover:not(:disabled){background-color:var(--surface-elevated);color:var(--text-primary)}.clear-selection-button:disabled{opacity:.6;cursor:not-allowed}.checkbox-column{width:40px;text-align:center}.checkbox-column input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.selected-row{background-color:#e8683514!important}.selected-row:hover{background-color:#e868351f!important}@media(max-width:768px){.bulk-actions-bar{flex-direction:column;gap:12px;align-items:flex-start}.bulk-action-buttons{flex-wrap:wrap;width:100%}}.upload-container{min-height:100vh;padding:2rem;max-width:1200px;margin:0 auto;animation:fadeIn .3s ease-in-out}.upload-card{background:var(--surface);border-radius:16px;box-shadow:var(--shadow-md);border:1px solid var(--border);padding:2.5rem;max-width:900px;margin:0 auto}.upload-header{margin-bottom:2.5rem}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--background-alt);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.875rem;font-weight:500;margin-bottom:1.5rem;transition:all .2s}.header-content h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.business-id{color:var(--text-secondary);font-size:.9375rem}.badges-container{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.info-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem}.info-badge.template{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#5a67d8;border:1px solid rgba(102,126,234,.2)}.info-badge.aramex{background:linear-gradient(135deg,#f093fb1a,#f5576c1a);color:#d53f8c;border:1px solid rgba(240,147,251,.2)}.badge-label{opacity:.8;font-weight:500}.badge-value{font-weight:700}.alert{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border-radius:12px;margin-bottom:2rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert.error{flex-direction:row;align-items:center;background-color:#e74c3c1a;border:1px solid var(--error-color);color:var(--error-color)}.alert.success{background-color:#27ae601a;border:1px solid var(--success-color)}.alert-header{display:flex;align-items:center;gap:.75rem;color:var(--success-color)}.alert-title{font-weight:600}.success-details{padding-top:.75rem;border-top:1px solid rgba(39,174,96,.2);display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;font-size:.875rem}.detail-label{color:#155724cc}.detail-value{color:#155724;font-weight:600}.download-actions{display:flex;gap:1rem;margin-top:.75rem}.download-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;border-radius:6px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.download-btn.success{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.download-btn.success:hover{background-color:#bbf7d0}.download-btn.error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.download-btn.error:hover{background-color:#fecaca}.form-section{margin-bottom:2.5rem}.form-section h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.file-type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.file-type-card{position:relative;display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--surface);border:2px solid var(--border);border-radius:12px;text-align:left;transition:all .2s;cursor:pointer}.file-type-card:hover{border-color:var(--primary-light);background-color:var(--background-alt)}.file-type-card.selected{border-color:var(--primary-color);background-color:#e868350d}.file-type-icon{width:48px;height:48px;border-radius:10px;background-color:var(--background-alt);color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.file-type-card.selected .file-type-icon{background-color:var(--primary-color);color:#fff}.file-type-content h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.file-type-content p{font-size:.8125rem;color:var(--text-secondary)}.check-indicator{position:absolute;top:1rem;right:1rem;color:var(--primary-color)}.file-drop-zone{position:relative}.file-drop-zone input{display:none}.drop-zone-label{display:block;border:2px dashed var(--border);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background-color:var(--background-alt)}.drop-zone-label:hover{border-color:var(--primary-color);background-color:#e868350d}.drop-zone-label.has-file{border-style:solid;border-color:var(--border-light);background-color:var(--surface);padding:2rem}.file-empty-state{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon-large{width:64px;height:64px;border-radius:50%;background-color:var(--surface);color:var(--primary-color);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);margin-bottom:.5rem}.primary-text{font-size:1rem;font-weight:500;color:var(--text-primary)}.secondary-text{font-size:.875rem;color:var(--text-secondary)}.file-selected-state{display:flex;align-items:center;gap:1rem}.file-icon-large{width:48px;height:48px;background-color:var(--background-alt);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.file-info{flex:1;text-align:left}.file-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.file-size{font-size:.8125rem;color:var(--text-secondary)}.change-file-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.875rem;transition:all .2s}.change-file-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.aramex-section{background-color:#f093fb0d;border:1px solid rgba(240,147,251,.2);border-radius:12px;padding:1.5rem}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.section-header h2{margin:0;font-size:1rem}.optional-badge{background-color:#f093fb1a;color:#d53f8c;font-size:.75rem;padding:.125rem .5rem;border-radius:999px;font-weight:600}.section-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1.5rem}.file-drop-zone.small .drop-zone-label{padding:1.5rem}.upload-icon-small{width:40px;height:40px;border-radius:50%;background-color:var(--surface);color:#d53f8c;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.submit-btn{width:100%;padding:1rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s ease;box-shadow:0 4px 12px #e868354d;margin-top:2rem}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #e8683566}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-in-out}.modal-content{background:var(--surface);border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.modal-close-btn{width:32px;height:32px;border-radius:8px;background:var(--background-alt);border:none;color:var(--text-secondary);font-size:1.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.modal-close-btn:hover{background:var(--surface-elevated);color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;padding:2rem}.report-content{background-color:#1e1e1e;color:#d4d4d4;padding:1.5rem;border-radius:8px;font-family:Monaco,Menlo,Consolas,monospace;font-size:.8125rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;border:1px solid var(--border)}.modal-footer{padding:1.5rem 2rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:1rem}.secondary-btn{padding:.75rem 1.5rem;background:var(--surface);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s;text-decoration:none}.secondary-btn:hover{background:var(--background-alt);border-color:var(--text-secondary)}.primary-btn{padding:.75rem 1.5rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.primary-btn:hover{opacity:.9;transform:translateY(-1px)}.loading-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem;color:var(--text-secondary)}.fade-in{animation:fadeIn .4s ease-out}@media(max-width:768px){.upload-container{padding:1rem}.upload-card{padding:1.5rem}.upload-header{flex-direction:column;align-items:flex-start;gap:1rem}.file-type-grid{grid-template-columns:1fr}.modal-content{margin:0;height:100%;max-height:100%;border-radius:0}}.invoice-review-container{max-width:1400px;margin:0 auto;padding:2rem}.review-header{margin-bottom:2rem}.header-content h1{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem}.header-content .subtitle{color:var(--text-secondary);font-size:1rem;margin:0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.spinner{border:4px solid var(--border);border-top:4px solid var(--primary-color);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background-color:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.error-icon{font-size:1.5rem}.file-info-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow-sm)}.file-info-card h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.25rem}.file-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.file-detail-item{display:flex;flex-direction:column;gap:.25rem}.file-detail-item .label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.file-detail-item .value{color:var(--text-primary);font-size:1rem;font-weight:600}.table-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:2rem;box-shadow:var(--shadow-md)}.table-wrapper{overflow-x:auto;max-height:600px;overflow-y:auto}.invoice-table{width:100%;border-collapse:collapse;font-size:.875rem}.invoice-table thead{position:sticky;top:0;z-index:10;background:var(--surface-elevated)}.invoice-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border);white-space:nowrap;background:var(--surface-elevated)}.invoice-table tbody tr{border-bottom:1px solid var(--border);transition:background-color .2s ease}.invoice-table tbody tr:hover{background-color:var(--surface-elevated)}.invoice-table tbody tr:last-child{border-bottom:none}.invoice-table td{padding:.875rem 1rem;color:var(--text-primary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invoice-table .row-number{width:60px;text-align:center;font-weight:600;color:var(--text-secondary);background:var(--surface-elevated);position:sticky;left:0;z-index:5}.invoice-table thead .row-number{z-index:15}.action-buttons{display:flex;justify-content:flex-end;gap:1rem;padding:2rem 0;margin-top:2rem;position:relative;z-index:1}.no-data{text-align:center;padding:2rem;color:var(--text-secondary);font-size:1rem}.btn{padding:.75rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #e868354d}.btn-secondary{background:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--background-alt);border-color:var(--text-secondary)}[data-theme=dark] .error-message{background-color:#dc26261a;border-color:#dc26264d;color:#fca5a5}@media(max-width:768px){.invoice-review-container{padding:1rem}.header-content h1{font-size:1.5rem}.file-details{grid-template-columns:1fr}.table-wrapper{max-height:500px}.invoice-table{font-size:.75rem}.invoice-table th,.invoice-table td{padding:.5rem}.action-buttons{flex-direction:column-reverse}.btn{width:100%}}@media print{.action-buttons{display:none}.table-wrapper{max-height:none;overflow:visible}.invoice-table thead{position:static}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content.mapping-modal{background:var(--surface);border-radius:12px;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);border:1px solid var(--border);animation:slideUp .3s ease-out}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.modal-close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:.5rem;line-height:1;border-radius:50%;transition:all .2s}.modal-close-btn:hover{background-color:var(--surface-elevated);color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{padding:1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:1rem}.mapping-grid{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.mapping-row{display:grid;grid-template-columns:1fr 40px 1fr;align-items:center;gap:1rem;padding:.75rem;background:var(--surface-elevated);border-radius:8px;border:1px solid var(--border)}.expected-col label{font-weight:500;color:var(--text-primary);display:block}.arrow{text-align:center;color:var(--text-secondary);font-weight:700}.file-col select{width:100%;padding:.5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);font-size:.9rem}.file-col select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #e868351a}.file-col select.unmapped{border-color:#fbbf24;border-style:dashed}.description{color:var(--text-secondary);font-size:.95rem;margin-bottom:1rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tooltip-container{display:inline-block;margin-left:.5rem;position:relative;cursor:help}.info-icon{font-size:.85rem;color:var(--text-secondary);opacity:.7}.tooltip-container:hover .info-icon{opacity:1;color:var(--primary-color)}.tooltip-text{visibility:hidden;width:250px;background-color:#333;color:#fff;text-align:left;border-radius:6px;padding:.75rem;position:absolute;z-index:1050;bottom:125%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .2s;font-size:.8rem;font-weight:400;box-shadow:0 4px 12px #00000026;pointer-events:none;line-height:1.4}.tooltip-text:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#333 transparent transparent transparent}.tooltip-container:hover .tooltip-text{visibility:visible;opacity:1}.mapping-modal .modal-body{overflow-x:hidden}.expected-col,.expected-col label{display:flex;align-items:center}.mapping-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--surface-elevated);border-radius:8px;border:1px solid var(--border);flex-wrap:wrap;gap:1rem}.load-mapping{display:flex;align-items:center;gap:.5rem}.load-mapping label{font-weight:500;color:var(--text-secondary)}.load-mapping select{padding:.4rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);min-width:200px}.save-input-group{display:flex;align-items:center;gap:.5rem}.save-input-group input{padding:.4rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary)}.btn-sm{padding:.4rem .8rem;font-size:.875rem;height:32px}.btn-outline{border:1px solid var(--primary-color);color:var(--primary-color);background:transparent}.btn-outline:hover{background:#e868351a}.btn-text{background:transparent;color:var(--text-secondary);padding:.4rem}.btn-text:hover{color:var(--text-primary);background:var(--surface-hover)}.saved-mappings-section{display:flex;justify-content:space-between;align-items:center;background-color:var(--surface-elevated);padding:1rem;border-radius:8px;border:1px solid var(--border);margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.retreive-mapping,.save-mapping{display:flex;align-items:center;gap:.75rem}.retreive-mapping label{font-weight:500;color:var(--text-secondary);font-size:.9rem}.mapping-select{padding:.5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);min-width:200px}.mapping-name-input{padding:.5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-primary);width:200px}.btn-sm{padding:.5rem 1rem;font-size:.85rem}@media(max-width:768px){.saved-mappings-section,.retreive-mapping,.save-mapping{flex-direction:column;align-items:stretch}.mapping-select,.mapping-name-input{width:100%}}.sleek-select,.sleek-input{appearance:none;-webkit-appearance:none;background-color:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.6rem 1rem;font-size:.9rem;color:var(--text-primary);width:100%;transition:all .2s ease;box-shadow:var(--shadow-sm)}.sleek-select{padding-right:2rem;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem center;background-size:1rem}.select-wrapper{position:relative;width:100%}.sleek-select:focus,.sleek-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #e8683526}.sleek-select:hover,.sleek-input:hover{border-color:var(--text-secondary)}.sleek-select.unmapped{border-color:#f59e0b;border-style:solid;background-color:#fffbeb}[data-theme=dark] .sleek-select.unmapped{background-color:#451a03}.status-message{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem;animation:fadeIn .3s ease-out}.status-message.success{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-message.error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}[data-theme=dark] .status-message.success{background-color:#16653433;color:#86efac;border-color:#16653466}[data-theme=dark] .status-message.error{background-color:#991b1b33;color:#fca5a5;border-color:#991b1b66}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.mapping-row{border:none;background:var(--surface);border-bottom:1px solid var(--border);padding:1rem 0;border-radius:0}.mapping-row:last-child{border-bottom:none}.upload-history-container{padding:2rem;max-width:1200px;margin:0 auto;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.header-left{display:flex;flex-direction:column;gap:1rem}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--background-alt);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:.875rem;font-weight:500;width:fit-content;transition:all .2s}.back-button:hover{background-color:var(--surface-elevated);color:var(--text-primary);border-color:var(--border-light)}.page-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.subtitle{color:var(--text-secondary);font-size:.875rem}.refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background-color:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-weight:500;transition:all .2s;box-shadow:var(--shadow-sm);margin-top:.5rem}.refresh-btn:hover:not(:disabled){background-color:var(--background-alt);border-color:var(--border-light)}.refresh-btn:disabled{opacity:.7;cursor:wait}.history-card{background:var(--surface);border-radius:12px;box-shadow:var(--shadow-md);border:1px solid var(--border);overflow:hidden}.history-table{width:100%;border-collapse:collapse;min-width:900px}.history-table th{background-color:var(--background-alt);padding:1rem 1.5rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.history-table td{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:.9375rem;vertical-align:middle}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover{background-color:var(--surface-elevated)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.8125rem;font-weight:600;text-transform:capitalize}.status-badge svg{width:14px;height:14px}.status-badge.success{background-color:#27ae6026;color:var(--success-color)}.status-badge.warning{background-color:#f39c1226;color:var(--warning-color)}.status-badge.error{background-color:#e74c3c26;color:var(--error-color)}.status-badge.info{background-color:#3498db26;color:#3498db}.status-badge.default{background-color:var(--background-alt);color:var(--text-secondary)}.action-link{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.action-link svg{width:14px;height:14px}.action-link.primary{color:var(--primary-color);background-color:#e868351a}.action-link.primary:hover{background-color:#e8683533}.action-link.success{color:var(--success-color);background-color:#27ae601a}.action-link.success:hover{background-color:#27ae6033}.action-link.error{color:var(--error-color);background-color:#e74c3c1a}.action-link.error:hover{background-color:#e74c3c33}.report-actions{display:flex;gap:.5rem;flex-wrap:wrap}.text-muted{color:var(--text-muted)}.empty-state{text-align:center;padding:4rem 2rem!important}.empty-content{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-muted)}.empty-content svg{width:48px;height:48px;opacity:.5}.empty-content h3{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--background-alt);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem;background-color:#e74c3c1a;border:1px solid var(--error-color);border-radius:8px;color:var(--error-color);margin-bottom:1.5rem}@media(max-width:768px){.upload-history-container{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-left{width:100%}.refresh-btn{width:100%;justify-content:center;margin-top:0}}.count-col{text-align:center;white-space:nowrap}.count-cell{text-align:center;font-weight:600;font-size:.95rem}.success-count{color:var(--success-color, #27ae60)}.error-count{color:var(--error-color, #e74c3c)}.pending-count{color:var(--warning-color, #f39c12)}.clickable-row{cursor:pointer;transition:background-color .15s ease}.clickable-row:hover{background-color:var(--surface-elevated, #f8f9fa)!important}.clickable-row:active{background-color:var(--background-alt, #f0f0f0)!important}.upload-detail-container{max-width:1400px;margin:0 auto;padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.header-left{display:flex;align-items:flex-start;gap:1.5rem}.back-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color, #e5e5e5);border-radius:8px;cursor:pointer;color:var(--text-secondary, #666);transition:all .2s}.back-button:hover{background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #333)}.page-header h1{margin:0;font-size:1.75rem;font-weight:600;color:var(--text-primary, #111)}.page-header .subtitle{margin:.25rem 0 0;color:var(--text-secondary, #666);font-size:.9rem}.refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-color, #4f46e5);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.refresh-btn:hover:not(:disabled){background:var(--primary-hover, #4338ca)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin-bottom:1.5rem}.summary-card{background:#fff;border-radius:12px;border:1px solid var(--border-color, #e5e5e5);padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.summary-date{color:var(--text-secondary, #666);font-size:.9rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:1.25rem;border-radius:10px;background:var(--bg-secondary, #f9fafb)}.stat-item.total{background:#f0f4ff}.stat-item.success{background:#ecfdf5}.stat-item.error{background:#fef2f2}.stat-item.pending{background:#fefce8}.stat-value{font-size:2rem;font-weight:700}.stat-item.total .stat-value{color:#4f46e5}.stat-item.success .stat-value{color:#059669}.stat-item.error .stat-value{color:#dc2626}.stat-item.pending .stat-value{color:#ca8a04}.stat-label{font-size:.85rem;color:var(--text-secondary, #666);margin-top:.25rem}.report-links{display:flex;gap:1rem;flex-wrap:wrap}.report-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;text-decoration:none;transition:all .2s}.report-btn.primary{background:#e0e7ff;color:#4f46e5}.report-btn.primary:hover{background:#c7d2fe}.report-btn.success{background:#d1fae5;color:#059669}.report-btn.success:hover{background:#a7f3d0}.report-btn.error{background:#fee2e2;color:#dc2626}.report-btn.error:hover{background:#fecaca}.results-card{background:#fff;border-radius:12px;border:1px solid var(--border-color, #e5e5e5);overflow:hidden;box-shadow:0 1px 3px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #e5e5e5)}.results-header h2{margin:0;font-size:1.25rem;font-weight:600}.filter-controls{display:flex;gap:1rem}.status-filter{padding:.5rem 1rem;border:1px solid var(--border-color, #e5e5e5);border-radius:6px;font-size:.875rem;background:#fff;cursor:pointer}.table-responsive{overflow-x:auto}.results-table{width:100%;border-collapse:collapse}.results-table th{text-align:left;padding:.875rem 1rem;background:#f9fafb;font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #666);border-bottom:1px solid var(--border-color, #e5e5e5)}.results-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border-color, #e5e5e5);font-size:.9rem}.results-table tbody tr:hover{background:#f9fafb}.results-table .error-row{background:#fef2f2}.results-table .error-row:hover{background:#fee2e2}.invoice-number{font-weight:500;font-family:monospace}.irn-cell{font-family:monospace;font-size:.8rem;color:var(--text-secondary, #666)}.error-cell .error-text{color:#dc2626;font-size:.85rem;max-width:300px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.date-cell{white-space:nowrap;color:var(--text-secondary, #666)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-badge.large{padding:.5rem 1rem;font-size:.875rem}.status-badge.success{background:#d1fae5;color:#059669}.status-badge.warning{background:#fef3c7;color:#d97706}.status-badge.error{background:#fee2e2;color:#dc2626}.status-badge.info{background:#dbeafe;color:#2563eb}.status-badge.default{background:#f3f4f6;color:#6b7280}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem}.spinner{width:2rem;height:2rem;border:3px solid var(--border-color, #e5e5e5);border-top-color:var(--primary-color, #4f46e5);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem 2rem}.empty-content p{color:var(--text-secondary, #666);margin:0}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem;border-top:1px solid var(--border-color, #e5e5e5)}.pagination-btn{padding:.5rem 1rem;background:#fff;border:1px solid var(--border-color, #e5e5e5);border-radius:6px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary, #f5f5f5)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.9rem;color:var(--text-secondary, #666)}@media(max-width:768px){.upload-detail-container{padding:1rem}.page-header{flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.summary-header{flex-direction:column;gap:.75rem;align-items:flex-start}.filter-controls,.status-filter{width:100%}}.settings-container{max-width:900px;margin:0 auto;padding:40px 20px}.settings-header{margin-bottom:32px}.back-button{padding:10px 20px;background-color:var(--surface-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-size:14px;margin-bottom:16px;transition:all .3s ease;cursor:pointer}.back-button:hover{background-color:var(--background-alt);border-color:var(--border-light);color:var(--text-primary)}.settings-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:8px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-header p{color:var(--text-secondary);font-size:15px}.settings-tabs{display:flex;gap:8px;margin-bottom:32px;border-bottom:2px solid var(--border);padding-bottom:0}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:15px;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;bottom:-2px}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:600}.settings-content{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;box-shadow:var(--shadow-lg)}.settings-form{max-width:700px}.settings-form h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.form-description{color:var(--text-secondary);font-size:14px;margin-bottom:32px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:14px 18px;background-color:var(--surface-elevated);border:1px solid var(--border);border-radius:10px;font-size:15px;color:var(--text-primary);transition:all .3s ease;font-family:inherit}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #e868351a;background-color:var(--surface)}.form-group input:disabled,.form-group textarea:disabled{background-color:var(--background-alt);cursor:not-allowed;opacity:.6}.field-hint{display:block;margin-top:6px;font-size:13px;color:var(--text-muted)}.submit-button{padding:14px 32px;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;transition:all .3s ease;margin-top:24px;box-shadow:0 4px 12px #e868354d;cursor:pointer}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #e8683566}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#ef44441a;border:1px solid var(--error-color);color:var(--error-color);padding:12px 16px;border-radius:10px;margin-bottom:24px;font-size:14px}.success-message{background-color:#22c55e1a;border:1px solid var(--success-color);color:var(--success-color);padding:12px 16px;border-radius:10px;margin-bottom:24px;font-size:14px}@media(max-width:768px){.settings-container{padding:24px 16px}.settings-content{padding:24px 20px}.settings-header h1{font-size:26px}.settings-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{padding:12px 16px;font-size:14px;white-space:nowrap}.form-row{grid-template-columns:1fr;gap:0}.settings-form h2{font-size:20px}}.country-select-container{position:relative}.country-search-input{width:100%}.country-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;max-height:250px;overflow-y:auto;z-index:100;margin-top:4px;box-shadow:var(--shadow-lg);list-style:none;padding:8px 0}.country-option{padding:12px 16px;cursor:pointer;font-size:14px;color:var(--text-primary);transition:background-color .2s ease}.country-option:hover{background-color:var(--surface-elevated)}.country-option.no-results{color:var(--text-muted);cursor:default;font-style:italic}.country-option.no-results:hover{background-color:transparent}.selected-country{display:block;margin-top:6px;font-size:13px;color:var(--success-color);font-weight:500}.templates-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.templates-header{max-width:1200px;margin:0 auto 2rem}.templates-header .back-button{background:#fff3;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;margin-bottom:1rem;transition:background .3s ease}.templates-header .back-button:hover{background:#ffffff4d}.header-content{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 8px 16px #0000001a}.header-content h1{margin:0 0 .5rem;color:#333;font-size:2rem}.header-content p{margin:0;color:#666;font-size:1rem}.templates-content{max-width:1200px;margin:0 auto}.section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 8px 16px #0000001a;margin-bottom:2rem}.section h2{margin:0 0 .5rem;color:#333;font-size:1.5rem}.section-description{margin:0 0 1.5rem;color:#666;font-size:.95rem}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.template-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;padding:1.5rem;transition:all .3s ease}.template-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.template-icon{font-size:2.5rem;margin-bottom:1rem}.template-card h3{margin:0 0 .5rem;color:#333;font-size:1.25rem}.template-description{color:#666;font-size:.9rem;margin:0 0 1rem;line-height:1.5}.template-features{list-style:none;padding:0;margin:1rem 0}.template-features li{color:#555;font-size:.85rem;padding:.25rem 0 .25rem 1.25rem;position:relative}.template-features li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700}.template-meta{margin-top:1rem;display:flex;gap:.5rem;flex-wrap:wrap}.template-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.template-badge.active{background:#d4edda;color:#155724}.template-badge.inactive{background:#f8d7da;color:#721c24}.assignment-form{max-width:600px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:600;font-size:.95rem}.form-select{width:100%;padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;background:#fff;color:#333;transition:border-color .3s ease}.form-select:focus{outline:none;border-color:#667eea}.current-template-info{background:#e7f3ff;border-left:4px solid #667eea;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.95rem;color:#333}.current-template-info strong{display:block;margin-bottom:.5rem}.template-name{color:#667eea;font-weight:600;font-size:1.1rem}.template-type-badge{display:inline-block;background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;margin-left:.5rem;text-transform:uppercase}.assign-button{background:#667eea;color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;max-width:300px}.assign-button:hover:not(:disabled){background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.assign-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.info-section{background:#f8f9fa;border:2px solid #e9ecef}.info-content p{color:#555;line-height:1.6;margin-bottom:1.5rem}.info-boxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-box{background:#fff;padding:1.5rem;border-radius:8px;border:1px solid #e9ecef}.info-box h4{margin:0 0 .75rem;color:#333;font-size:1.1rem}.info-box p{margin:0;color:#666;font-size:.9rem;line-height:1.5}.error-message{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:8px;padding:1rem;margin-bottom:1.5rem;font-size:.95rem}.success-message{background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:8px;padding:1rem;margin-bottom:1.5rem;font-size:.95rem}.loading-message{text-align:center;padding:4rem 2rem;color:#fff;font-size:1.25rem}@media(max-width:768px){.templates-container{padding:1rem}.templates-grid{grid-template-columns:1fr}.header-content h1{font-size:1.5rem}.section{padding:1.5rem}.info-boxes{grid-template-columns:1fr}}.admin-management-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.admin-management-header{background:#fff;border-radius:10px;padding:30px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.admin-management-header h1{margin:0;color:#333;font-size:2rem}.header-subtitle{margin:8px 0 0;color:#666;font-size:1rem}.back-button{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:1rem;transition:transform .2s,box-shadow .2s}.back-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.admin-management-main{max-width:1200px;margin:0 auto}.info-section{margin-bottom:30px}.info-card{background:#fff;border-radius:10px;padding:25px;box-shadow:0 2px 10px #0000001a}.info-card h3{margin:0 0 15px;color:#333;font-size:1.5rem}.info-card p{margin:10px 0;color:#666;line-height:1.6}.info-card ul{margin:15px 0;padding-left:25px;color:#666;line-height:1.8}.info-card li{margin:8px 0}.info-note{background:#f0f4ff;padding:15px;border-radius:5px;border-left:4px solid #667eea;margin-top:15px}.info-note strong{color:#667eea}.management-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:30px;margin-bottom:30px}.management-card{background:#fff;border-radius:10px;padding:30px;box-shadow:0 2px 10px #0000001a}.management-card h2{margin:0 0 10px;color:#333;font-size:1.5rem}.management-card>p{margin:0 0 25px;color:#666;font-size:.95rem}.admin-form{margin-top:20px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:.95rem}.form-group input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:5px;font-size:1rem;transition:border-color .3s,box-shadow .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.promote-button,.revoke-button{width:100%;padding:12px 24px;border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:500;transition:transform .2s,box-shadow .2s;color:#fff}.promote-button{background:linear-gradient(135deg,#11998e,#38ef7d)}.promote-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #11998e66}.revoke-button{background:linear-gradient(135deg,#eb3349,#f45c43)}.revoke-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #eb334966}.promote-button:disabled,.revoke-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.message-container{margin:30px 0}.error-message{background:#fee;color:#c33;padding:15px 20px;border-radius:5px;border-left:4px solid #c33;font-size:.95rem}.success-message{background:#efe;color:#393;padding:15px 20px;border-radius:5px;border-left:4px solid #393;font-size:.95rem}.security-section{background:#fff;border-radius:10px;padding:30px;box-shadow:0 2px 10px #0000001a;margin-top:30px}.security-section h3{margin:0 0 20px;color:#333;font-size:1.5rem}.security-card{background:#f9f9f9;padding:20px;border-radius:8px;margin-bottom:15px;border-left:4px solid #667eea}.security-card:last-child{margin-bottom:0}.security-card h4{margin:0 0 10px;color:#667eea;font-size:1.1rem}.security-card p{margin:0;color:#666;line-height:1.6;font-size:.95rem}@media(max-width:768px){.admin-management-container{padding:15px}.admin-management-header{padding:20px}.admin-management-header h1{font-size:1.5rem}.header-content{flex-direction:column;align-items:flex-start}.back-button{width:100%}.management-section{grid-template-columns:1fr;gap:20px}.management-card,.info-card,.security-section{padding:20px}}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #e86835;--primary-hover: #d4551f;--primary-light: #ff8a5b;--secondary-color: #2c3e50;--accent-color: #34495e;--success-color: #27ae60;--error-color: #e74c3c;--warning-color: #f39c12;--background: #ffffff;--background-alt: #f8f9fa;--surface: #ffffff;--surface-elevated: #f1f5f9;--border: #e2e8f0;--border-light: #cbd5e1;--text-primary: #1a202c;--text-secondary: #4a5568;--text-muted: #718096;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--gradient-primary: linear-gradient(135deg, #e86835 0%, #d4551f 100%);--gradient-dark: linear-gradient(135deg, #f8f9fa 0%, #e2e8f0 100%)}[data-theme=dark]{--background: #0f1419;--background-alt: #1a1f2e;--surface: #1e2530;--surface-elevated: #252d3d;--border: #2d3748;--border-light: #3d4757;--text-primary: #e8e9ed;--text-secondary: #a0aec0;--text-muted: #718096;--shadow-sm: 0 2px 4px 0 rgba(0, 0, 0, .3);--shadow-md: 0 6px 12px -2px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 24px -4px rgba(0, 0, 0, .5);--gradient-dark: linear-gradient(135deg, #1e2530 0%, #0f1419 100%)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-primary)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.6}.error-message{background-color:#e74c3c1a;border:1px solid var(--error-color);color:#ff6b6b;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.success-message{background-color:#27ae601a;border:1px solid var(--success-color);color:#51cf66;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}
