*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";background:linear-gradient(180deg,#f8fafc,#f1f5f9);background-attachment:fixed;color:#1e293b;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{min-height:100vh;display:flex}.sidebar{width:240px;background:linear-gradient(180deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-brand{padding:1.5rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:36px;height:36px;filter:invert(1)}.sidebar-title{font-size:1.125rem;font-weight:600;letter-spacing:-.025em}.sidebar-nav{flex:1;padding:1rem 0;display:flex;flex-direction:column;gap:.25rem}.impersonation-banner{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#1e293b;font-size:.8125rem}.impersonation-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.impersonation-label{font-size:.6875rem;text-transform:uppercase;font-weight:600;opacity:.7;letter-spacing:.05em}.impersonation-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.impersonation-company{font-size:.75rem;opacity:.8}.impersonation-exit{background:#00000026;border:1px solid rgba(0,0,0,.2);color:#1e293b;padding:.25rem .625rem;border-radius:.375rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s ease;white-space:nowrap;flex-shrink:0}.impersonation-exit:hover{background:#00000040}.sidebar-link{display:block;padding:.75rem 1.5rem;color:#ffffffb3;text-decoration:none;font-size:.9375rem;font-weight:500;transition:all .15s ease;border-left:3px solid transparent}.sidebar-link:hover{color:#fff;background:#ffffff0d}.sidebar-link.active{color:#fff;background:#ffffff1a;border-left-color:#7c3aed}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-version{margin-top:.75rem;font-size:.6875rem;color:#fff6;text-align:center}.sidebar-user{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8125rem;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{display:block;font-size:.8125rem;font-weight:500;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{background:none;border:none;padding:0;color:#ffffff80;font-size:.75rem;cursor:pointer;transition:color .15s ease}.btn-logout:hover{color:#fffc}.main-content{flex:1;margin-left:240px;padding:2rem;max-width:1640px;width:100%}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014,0 4px 12px #0000000d;padding:1.5rem;transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:0 4px 12px #0000001a,0 8px 24px #00000014}.card-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid #e5e7eb}.card-header h2,.card-header h3{font-size:1.125rem;font-weight:600;color:#1e293b}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;box-shadow:0 2px 8px #4f46e540}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #4f46e559}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-ghost{background:transparent;color:#6b7280;padding:.5rem}.btn-ghost:hover:not(:disabled){background:#f3f4f6;color:#1e293b}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98140}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #10b98159}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444440}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #ef444459}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb;border-color:#d1d5db}.badge{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-pending{background:#fef3c7;color:#92400e}.badge-approved{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.badge-error{background:#fecaca;color:#7f1d1d}.badge-duplicate{background:#e5e7eb;color:#374151}.badge-waiting{background:#dbeafe;color:#1e40af}.badge-processing{background:#e0e7ff;color:#3730a3}.document-type-badge{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.document-type-invoice{background:#d1fae5;color:#065f46}.document-type-receipt{background:#dbeafe;color:#1e40af}.document-type-statement{background:#fef3c7;color:#92400e}.document-type-image{background:#e5e7eb;color:#374151}.document-type-flyer{background:#fed7aa;color:#9a3412}.document-type-other{background:#f3f4f6;color:#6b7280}.type-filter{margin-left:1rem}.type-select{padding:.5rem 1rem;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;font-size:.875rem;cursor:pointer}.type-select:hover{border-color:#d1d5db}.type-select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}input,textarea,select{width:100%;padding:.625rem .875rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;background:#f9fafb;transition:all .2s ease}input::placeholder,textarea::placeholder{color:#9ca3af}input:focus,textarea:focus,select:focus{outline:none;border-color:#4f46e5;background:#fff;box-shadow:0 0 0 3px #4f46e51a}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:#374151}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}table{width:100%;border-collapse:collapse}th,td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}th{font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:#f9fafb}tbody tr{transition:background-color .15s ease}tbody tr:hover{background:#f8fafc}.table-modern{border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;background:#fff}.table-modern table{margin:0}.table-modern th{background:linear-gradient(180deg,#f9fafb,#f3f4f6);position:sticky;top:0;z-index:10}.table-modern th:first-child{border-top-left-radius:12px}.table-modern th:last-child{border-top-right-radius:12px}.table-modern tbody tr:last-child td{border-bottom:none}.table-modern tbody tr:nth-child(2n){background:#fafbfc}.table-modern tbody tr:hover{background:#f0f4ff}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:#6b7280}.error{color:#dc2626;padding:1rem;background:#fee2e2;border-radius:8px;border:1px solid #fecaca}.page-header{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#1a1a2e,#4f46e5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.025em;margin-bottom:.5rem}.page-header .page-icon{-webkit-text-fill-color:initial;background:none;-webkit-background-clip:initial;background-clip:initial}.page-subtitle{color:#6b7280;font-size:1rem;margin-bottom:1.5rem}.stats-card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 1px 3px #00000014;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.25rem}.stats-card .stats-value{font-size:1.75rem;font-weight:700;color:#1e293b}.stats-card .stats-label{font-size:.875rem;color:#6b7280}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:#6b7280}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:.5rem}.empty-state-description{font-size:.875rem;max-width:300px}.filter-bar{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb;margin-bottom:1.5rem}.filter-bar select,.filter-bar input{min-width:150px;flex:1}.tab-button{padding:.625rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.tab-button:hover{color:#4f46e5}.tab-button.active{color:#4f46e5;border-bottom-color:#4f46e5}.section-title{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#f9fafb;border-radius:8px;cursor:pointer;font-weight:600;color:#1e293b;transition:background-color .2s ease}.section-title:hover{background:#f3f4f6}.section-title .toggle-icon{transition:transform .2s ease}.section-title.expanded .toggle-icon{transform:rotate(180deg)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:1rem}.login-container{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:72px;height:72px;margin:0 auto 1rem}.login-logo-icon{width:100%;height:100%;filter:invert(1)}.login-title{color:#fff;font-size:2rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.025em}.login-subtitle{color:#fff9;font-size:.95rem}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:2.5rem;width:100%}.login-card-title{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin-bottom:.5rem;text-align:center}.login-card-subtitle{color:#6b7280;font-size:.9rem;text-align:center;margin-bottom:1.5rem}.login-error{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem}.login-error-icon{font-size:1rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-field{display:flex;flex-direction:column;gap:.5rem}.login-label{font-size:.875rem;font-weight:500;color:#374151}.login-input{padding:.875rem 1rem;border:1px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#f9fafb}.login-input:focus{outline:none;border-color:#4f46e5;background:#fff;box-shadow:0 0 0 3px #4f46e51a}.login-input::placeholder{color:#9ca3af}.login-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #4f46e566}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{color:#ffffff80;font-size:.8rem;margin-top:2rem;text-align:center}.invoices-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-actions{display:flex;gap:.75rem;align-items:center}.filter-card{margin-bottom:1.5rem;padding:0;overflow:hidden}.status-tabs{display:flex;overflow-x:auto;border-bottom:1px solid #e5e7eb;background:#fafbfc;padding:0 .5rem}.filter-divider{height:1px;background:#e5e7eb}.filter-controls{display:flex;gap:1.5rem;padding:1rem 1.5rem;flex-wrap:wrap;align-items:flex-end}.search-field{flex:1;min-width:250px}.search-field input{width:100%}.vat-filter{display:flex;align-items:center;gap:.5rem;min-width:150px}.vat-filter input{width:150px}.date-filters{display:flex;gap:1rem;align-items:flex-end}.date-field{display:flex;flex-direction:column;gap:.375rem}.date-label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.date-field input{width:150px}.table-card{padding:0;overflow:visible}.table-card .loading,.table-card .error{margin:1.5rem}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background-color .15s ease}.sortable-header:hover{background:#f3f4f6}.sort-icon{margin-left:.25rem;opacity:.3;transition:opacity .15s ease}.sort-icon.active{opacity:1;color:#4f46e5}.clickable-row{cursor:pointer;transition:all .15s ease}.clickable-row:hover{background:#f0f4ff!important}.clickable-row:hover .arrow-cell{opacity:1;transform:translate(2px)}.vendor-cell{display:flex;align-items:center;gap:.75rem}.vendor-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.vendor-name{font-weight:500;color:#1e293b}.amount-cell .amount-value{font-weight:600;color:#1e293b}.confidence-indicator{display:flex;align-items:center;gap:.5rem}.confidence-bar{width:50px;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.confidence-fill{height:100%;border-radius:3px;transition:width .3s ease}.confidence-text{font-weight:600;font-size:.875rem}.date-cell{color:#6b7280}.arrow-cell{opacity:0;color:#4f46e5;font-weight:600;transition:all .15s ease}.pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#fafbfc;flex-wrap:wrap;gap:1rem}.pagination-info{font-size:.875rem;color:#6b7280}.pagination-controls{display:flex;align-items:center;gap:.75rem}.pagination-btn{border-radius:8px;font-weight:500}.pagination-btn:disabled{opacity:.4}.pagination-current{font-weight:600;color:#1e293b;padding:.5rem .75rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#4f46e51a,#7c3aed1a);display:flex;align-items:center;justify-content:center;z-index:50;pointer-events:none;animation:pulse-bg 1.5s ease-in-out infinite}.drop-overlay:before{content:"";position:absolute;top:16px;right:16px;bottom:16px;left:16px;border:3px dashed #4f46e5;border-radius:16px;animation:border-pulse 1.5s ease-in-out infinite}@keyframes pulse-bg{0%,to{opacity:.8}50%{opacity:1}}@keyframes border-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.002)}}.drop-overlay-content{background:#fff;padding:3rem 4rem;border-radius:16px;box-shadow:0 20px 60px #00000026;text-align:center;animation:bounce-in .3s ease-out}@keyframes bounce-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.drop-overlay-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.drop-overlay-text{font-size:1.5rem;font-weight:600;background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.drop-overlay-hint{font-size:.875rem;color:#6b7280}.table-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;background:#f8fafc}.table-toolbar-left{display:flex;align-items:center;gap:.75rem}.table-toolbar-right{display:flex;align-items:center;gap:.5rem}.table-result-count{font-size:.875rem;color:#6b7280;font-weight:500}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.column-config-wrapper{position:relative}.column-config-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026,0 2px 10px #0000001a;border:1px solid #e5e7eb;min-width:220px;z-index:1000;overflow:hidden}.column-config-header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid #e5e7eb;background:#f8fafc}.column-config-header span{font-weight:600;font-size:.875rem;color:#1e293b}.column-config-reset{background:none;border:none;color:#4f46e5;font-size:.75rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .15s ease}.column-config-reset:hover{background:#e0e7ff}.column-config-list{padding:.5rem 0;max-height:300px;overflow-y:auto}.column-config-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;cursor:pointer;transition:background .15s ease;font-size:.875rem;color:#374151}.column-config-item:hover{background:#f3f4f6}.column-config-item input[type=checkbox]{width:16px;height:16px;accent-color:#4f46e5;cursor:pointer}.column-config-item span{flex:1}.export-menu-wrapper{position:relative}.export-caret{font-size:.65rem;margin-left:.25rem;opacity:.7}.export-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026,0 2px 10px #0000001a;border:1px solid #e5e7eb;min-width:260px;z-index:1000;overflow:hidden;animation:exportMenuIn .15s ease-out}@keyframes exportMenuIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.export-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;border:none;background:none;cursor:pointer;text-align:left;transition:background .15s ease}.export-menu-item:hover{background:#f3f4f6}.export-menu-item:not(:last-child){border-bottom:1px solid #f3f4f6}.export-menu-icon{font-size:1.25rem;flex-shrink:0}.export-menu-label{display:block;font-weight:600;font-size:.875rem;color:#1e293b}.export-menu-desc{display:block;font-size:.75rem;color:#6b7280;margin-top:.125rem}.modal-backdrop,.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:.25rem;line-height:1;border-radius:.25rem;transition:color .2s,background-color .2s}.modal-close:hover{color:#1f2937;background-color:#f3f4f6}.modal-content form{padding:1.5rem}.modal-content .form-group{margin-bottom:1rem}.modal-content .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.modal-content .form-group input,.modal-content .form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.modal-content .form-group input:focus,.modal-content .form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.modal-content .error-text{color:#dc2626;font-size:.875rem;margin-top:1rem}.batch-upload-modal{background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.batch-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.batch-modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.batch-modal-loading,.batch-modal-error{padding:3rem;text-align:center;color:#6b7280}.batch-modal-error{color:#dc2626}.batch-modal-summary{padding:1.5rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.batch-filename{font-weight:600;font-size:1rem;margin-bottom:1rem;color:#111827}.batch-progress-container{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.batch-progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.batch-progress-fill{height:100%;background:linear-gradient(135deg,#8b5cf6,#6366f1);transition:width .3s ease}.batch-progress-text{font-size:.875rem;font-weight:600;color:#6366f1;min-width:3rem}.batch-stats{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.batch-stat{font-size:.875rem;padding:.25rem .5rem;border-radius:.25rem}.batch-stat-total{background:#e5e7eb;color:#374151}.batch-stat-success{background:#d1fae5;color:#065f46}.batch-stat-duplicate{background:#fef3c7;color:#92400e}.batch-stat-failed{background:#fee2e2;color:#991b1b}.batch-status{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.batch-status-pending{background:#e5e7eb;color:#374151}.batch-status-processing{background:#dbeafe;color:#1e40af;animation:pulse 2s infinite}.batch-status-completed{background:#d1fae5;color:#065f46}.batch-status-failed{background:#fee2e2;color:#991b1b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.batch-modal-items{flex:1;overflow-y:auto;padding:1rem 1.5rem}.batch-items-header{font-weight:600;font-size:.875rem;color:#6b7280;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.batch-items-list{display:flex;flex-direction:column;gap:.5rem}.batch-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:.5rem;background:#f9fafb;border:1px solid #e5e7eb;font-size:.875rem}.batch-item-icon{width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:600}.batch-item-pending .batch-item-icon{background:#e5e7eb;color:#6b7280}.batch-item-processing .batch-item-icon{background:#dbeafe;color:#1e40af;animation:spin 1s linear infinite}.batch-item-success .batch-item-icon{background:#d1fae5;color:#065f46}.batch-item-duplicate .batch-item-icon{background:#fef3c7;color:#92400e}.batch-item-failed .batch-item-icon{background:#fee2e2;color:#991b1b}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.batch-item-filename{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-item-size{color:#6b7280;font-size:.75rem}.batch-item-error{color:#dc2626;font-size:.75rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-item-link{color:#6366f1;font-size:.75rem;text-decoration:none}.batch-item-link:hover{text-decoration:underline}.batch-modal-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.batch-uploads-page{padding:2rem}.batch-uploads-page .page-header-section{margin-bottom:2rem}.batch-list .table-container{background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.batch-list .data-table{width:100%;border-collapse:collapse}.batch-list .data-table th{background:#f9fafb;padding:1rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;border-bottom:1px solid #e5e7eb}.batch-list .data-table td{padding:1rem;border-bottom:1px solid #e5e7eb}.batch-list .clickable-row{cursor:pointer;transition:background-color .15s}.batch-list .clickable-row:hover{background-color:#f9fafb}.batch-filename-cell{font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-progress-mini{display:flex;align-items:center;gap:.5rem}.batch-progress-mini .batch-progress-bar{width:80px;height:6px}.batch-progress-mini span{font-size:.75rem;color:#6b7280;min-width:2.5rem}.stat-success{color:#059669;font-weight:500}.stat-duplicate{color:#d97706;font-weight:500}.stat-failed{color:#dc2626;font-weight:500}.batch-detail{background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.batch-detail-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.batch-detail-header h2{flex:1;margin:0;font-size:1.25rem;font-weight:600}.batch-detail-summary{padding:1.5rem;border-bottom:1px solid #e5e7eb}.batch-detail-summary .batch-progress-container,.batch-detail-summary .batch-stats{margin-bottom:1rem}.batch-meta{display:flex;gap:2rem;font-size:.875rem;color:#6b7280}.batch-detail-items{padding:1.5rem}.batch-detail-items h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#374151}.batch-detail-items .batch-items-list{max-height:500px;overflow-y:auto}.public-layout{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#f8fafc,#f1f5f9)}.public-header{background:linear-gradient(180deg,#1a1a2e,#16213e);padding:1rem 2rem;position:sticky;top:0;z-index:100}.public-header-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.public-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:#fff}.public-logo-icon{width:40px;height:40px;filter:invert(1)}.public-logo-text{font-size:1.25rem;font-weight:600;letter-spacing:-.025em}.public-nav{display:flex;align-items:center;gap:1.5rem}.public-nav-link{color:#ffffffb3;text-decoration:none;font-size:.9375rem;font-weight:500;transition:color .2s ease}.public-nav-link:hover,.public-nav-link.active{color:#fff}.public-nav-cta{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:.625rem 1.25rem;border-radius:8px;text-decoration:none;font-weight:500;font-size:.9375rem;transition:all .2s ease;box-shadow:0 2px 8px #4f46e540}.public-nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px #4f46e559}.public-main{flex:1}.public-page{max-width:1200px;margin:0 auto;padding:3rem 2rem}.public-footer{background:linear-gradient(180deg,#1a1a2e,#16213e);color:#fff;padding:3rem 2rem 2rem;margin-top:auto}.public-footer-container{max-width:1200px;margin:0 auto}.public-footer-brand{margin-bottom:2rem}.public-footer-logo{width:40px;height:40px;margin-right:.5rem;filter:invert(1)}.public-footer-name{font-size:1.25rem;font-weight:600}.public-footer-tagline{color:#fff9;font-size:.9rem;margin-top:.5rem}.public-footer-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1)}.public-footer-section h4{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;color:#ffffffe6}.public-footer-section a,.public-footer-section p{display:block;color:#fff9;text-decoration:none;font-size:.9rem;line-height:1.8;transition:color .2s ease}.public-footer-section a:hover{color:#fff}.public-footer-bottom{padding-top:2rem;text-align:center;color:#ffffff80;font-size:.875rem}.home-page .hero-section{text-align:center;padding:4rem 0;margin-bottom:4rem}.hero-title{font-size:3rem;font-weight:700;color:#1a1a2e;line-height:1.2;margin-bottom:1.5rem}.hero-highlight{display:block;background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.25rem;color:#6b7280;max-width:700px;margin:0 auto 2rem;line-height:1.7}.hero-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.hero-cta-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:.875rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .2s ease;box-shadow:0 4px 16px #4f46e54d}.hero-cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4f46e566}.hero-cta-secondary{background:#fff;color:#4f46e5;padding:.875rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;border:2px solid #e5e7eb;transition:all .2s ease}.hero-cta-secondary:hover{border-color:#4f46e5;background:#f8fafc}.features-section{margin-bottom:4rem}.home-page .section-title{font-size:2rem;font-weight:700;color:#1a1a2e;text-align:center;margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature-card{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 12px #0000000d;border:1px solid #e5e7eb;text-align:center;transition:all .2s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.25rem;font-weight:600;color:#1a1a2e;margin-bottom:.75rem}.feature-card p{color:#6b7280;line-height:1.6;font-size:.95rem}.transparency-section{background:#fff;padding:3rem;border-radius:16px;margin-bottom:4rem;box-shadow:0 4px 12px #0000000d;border:1px solid #e5e7eb}.transparency-content{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.transparency-item{display:flex;gap:1rem;align-items:flex-start}.transparency-icon{font-size:1.5rem;flex-shrink:0}.transparency-item h4{font-size:1.1rem;font-weight:600;color:#1a1a2e;margin-bottom:.25rem}.transparency-item p{color:#6b7280;font-size:.95rem;line-height:1.6}.transparency-links{display:flex;gap:2rem;justify-content:center;padding-top:1.5rem;border-top:1px solid #e5e7eb}.transparency-links a{color:#4f46e5;text-decoration:none;font-weight:500;transition:color .2s ease}.transparency-links a:hover{color:#7c3aed}.contact-section{text-align:center}.contact-description{color:#6b7280;font-size:1.1rem;margin-bottom:2rem}.contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:900px;margin:0 auto}.contact-item{display:flex;gap:1rem;align-items:flex-start;text-align:left;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid #e5e7eb}.contact-icon{font-size:1.5rem;flex-shrink:0}.contact-item strong{display:block;color:#1a1a2e;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.contact-item a,.contact-item p{color:#6b7280;text-decoration:none;font-size:.95rem;line-height:1.6;margin:0}.contact-item a:hover{color:#4f46e5}.legal-page{max-width:800px}.legal-container{background:#fff;padding:3rem;border-radius:16px;box-shadow:0 4px 12px #0000000d;border:1px solid #e5e7eb}.legal-title{font-size:2.5rem;font-weight:700;color:#1a1a2e;margin-bottom:.5rem}.legal-effective,.legal-updated{color:#6b7280;font-size:.9rem;margin-bottom:.25rem}.legal-intro{padding:1.5rem;background:#f8fafc;border-radius:8px;margin:2rem 0;border-left:4px solid #4f46e5}.legal-intro p{margin:0;color:#374151;line-height:1.7}.legal-section{margin:2.5rem 0;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.legal-section:last-child{border-bottom:none;padding-bottom:0}.legal-section h2{font-size:1.5rem;font-weight:600;color:#1a1a2e;margin-bottom:1rem}.legal-section h3{font-size:1.125rem;font-weight:600;color:#374151;margin:1.5rem 0 .75rem}.legal-section h4{font-size:1rem;font-weight:600;color:#374151;margin:1rem 0 .5rem}.legal-section p{color:#4b5563;line-height:1.7;margin-bottom:1rem}.legal-section ul{margin:1rem 0;padding-left:1.5rem}.legal-section li{color:#4b5563;line-height:1.7;margin-bottom:.5rem}.legal-section li strong{color:#1a1a2e}.legal-section a{color:#4f46e5;text-decoration:none}.legal-section a:hover{text-decoration:underline}.legal-highlight{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1.5rem;margin:1.5rem 0}.legal-highlight h4{color:#1e40af;margin-top:0}.legal-highlight p{color:#1e40af;margin-bottom:0}.legal-address{font-style:normal;background:#f8fafc;padding:1rem 1.5rem;border-radius:8px;margin:1rem 0;line-height:1.8;color:#4b5563}.legal-address a{color:#4f46e5;text-decoration:none}.legal-address a:hover{text-decoration:underline}@media (max-width: 768px){.public-header-container{flex-direction:column;gap:1rem}.public-nav{flex-wrap:wrap;justify-content:center}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.legal-container{padding:1.5rem}.legal-title{font-size:1.75rem}}.login-legal-links{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-top:.75rem}.login-legal-links a{color:#fff9;text-decoration:none;font-size:.875rem;transition:color .2s ease}.login-legal-links a:hover{color:#ffffffe6}.login-legal-separator{color:#fff6;font-size:.75rem}.language-picker{display:flex;gap:.25rem;background:#ffffff1a;border-radius:6px;padding:.125rem}.language-picker-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;letter-spacing:.05em;transition:all .15s ease}.language-picker-btn:hover{color:#ffffffe6;background:#ffffff1a}.language-picker-btn.active{color:#fff;background:#fff3}.public-nav .language-picker{margin-left:.5rem}.sidebar-footer .language-picker{background:#ffffff14;margin-top:.5rem;align-self:center}
