.app-container{background-color:#f3f4f6;min-height:100vh}.app-header{background-color:#fff;box-shadow:0 1px 3px #0000001a}.header-content{justify-content:space-between;align-items:center;max-width:80rem;margin:0 auto;padding:1.5rem 2rem;display:flex}.header-title{color:#111827;font-size:1.875rem;font-weight:700}.header-subtitle{color:#6b7280;margin-top:.25rem}.logout-btn{color:#fff;cursor:pointer;background-color:#dc2626;border:none;border-radius:.5rem;padding:.5rem 1rem;transition:background-color .2s}.logout-btn:hover{background-color:#b91c1c}.main-content{max-width:80rem;margin:0 auto;padding:2rem 1.5rem}.summary-cards{grid-template-columns:repeat(1,1fr);gap:1.5rem;margin-bottom:2rem;display:grid}@media (min-width:768px){.summary-cards{grid-template-columns:repeat(3,1fr)}}.summary-card{background-color:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.summary-label{color:#6b7280;font-size:.875rem}.summary-value{color:#111827;margin-top:.5rem;font-size:1.875rem;font-weight:700}.total-value{color:#10b981}.low-stock-value{color:#ef4444}.actions-bar{background-color:#fff;border-radius:.5rem;flex-direction:column;gap:1rem;margin-bottom:1rem;padding:1rem;display:flex;box-shadow:0 1px 3px #0000001a}@media (min-width:640px){.actions-bar{flex-direction:row;justify-content:space-between}}.search-section{flex:1;gap:.5rem;display:flex}.search-input-wrapper{flex:1;position:relative}.search-icon{color:#9ca3af;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.search-input{border:1px solid #d1d5db;border-radius:.5rem;width:100%;padding:.5rem .75rem .5rem 2.5rem}.search-input:focus{ring:2px solid #3b82f6;border-color:#3b82f6;outline:none}.btn-search{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:.5rem;padding:.5rem 1rem;transition:background-color .2s}.btn-search:hover{background-color:#2563eb}.btn-reset{color:#fff;cursor:pointer;background-color:#6b7280;border:none;border-radius:.5rem;padding:.5rem 1rem;transition:background-color .2s}.btn-reset:hover{background-color:#4b5563}.btn-add-new{color:#fff;cursor:pointer;background-color:#10b981;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s;display:flex}.btn-add-new:hover{background-color:#059669}.action-buttons-group{align-items:center;gap:.75rem;display:flex}.btn-export-all{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex;box-shadow:0 1px 2px #0000000d}.btn-export-all:hover:not(:disabled){background:linear-gradient(135deg,#059669 0%,#047857 100%);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.btn-export-current{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex;box-shadow:0 1px 2px #0000000d}.btn-export-current:hover:not(:disabled){background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.btn-export-all:disabled,.btn-export-current:disabled{opacity:.6;cursor:not-allowed;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.search-tips{background-color:#eff6ff;border-left:4px solid #3b82f6;border-radius:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem}.search-tips-title{color:#1e40af;margin-bottom:.25rem;font-size:.875rem;font-weight:600}.search-tips-text{color:#1e3a8a;font-size:.875rem}.search-tips-text strong{background-color:#dbeafe;border-radius:.25rem;padding:.125rem .375rem;font-family:monospace}.search-info{background:#f9fafb;border-radius:.5rem;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.75rem;display:flex}.search-info-text{color:#374151;font-size:.875rem;font-weight:500}.view-toggle{gap:.5rem;display:flex}.view-toggle-btn{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.view-toggle-btn:hover{background:#f3f4f6;border-color:#9ca3af}.view-toggle-btn.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.table-container{background-color:#fff;border-radius:.5rem;overflow-x:auto;box-shadow:0 1px 3px #0000001a}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}.stock-table{border-collapse:collapse;width:100%;min-width:1000px;font-size:.875rem}.stock-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.stock-table th{text-align:left;color:#374151;white-space:nowrap;padding:.75rem 1rem;font-weight:600}.stock-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:.75rem 1rem}.stock-table tbody tr:hover{background-color:#f9fafb}.stock-table .low-stock-row{background-color:#fef2f2}.stock-table .low-stock-row:hover{background-color:#fee2e2}.part-number{color:#1f2937;font-family:monospace;font-weight:600}.id-cell{color:#6b7280;font-family:monospace;font-size:.8rem;font-weight:600}.description-cell{white-space:normal;word-break:break-word;max-width:250px;line-height:1.4}.quantity-number{margin-right:.5rem;display:inline-block}.low-quantity{color:#dc2626;font-weight:600}.low-stock-badge{cursor:help;font-size:.875rem;display:inline-block}.branch-badge{border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.branch-kelantan{color:#1e40af;background-color:#dbeafe}.branch-penang{color:#166534;background-color:#dcfce7}.branch-kl{color:#92400e;background-color:#fef3c7}.branch-default{color:#6b21a5;background-color:#f3e8ff}.actions-cell{white-space:nowrap}.quantity-controls-inline{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.quantity-input-small{text-align:center;border:1px solid #d1d5db;border-radius:.375rem;width:60px;padding:.375rem .5rem;font-size:.75rem}.quantity-input-small:focus{border-color:#3b82f6;outline:none}.btn-icon-small{cursor:pointer;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.375rem;transition:all .2s;display:inline-flex}.btn-add-small{color:#fff;background-color:#10b981}.btn-add-small:hover{background-color:#059669}.btn-remove-small{color:#fff;background-color:#eab308}.btn-remove-small:hover{background-color:#ca8a04}.btn-edit-small{color:#fff;background-color:#3b82f6}.btn-edit-small:hover{background-color:#2563eb}.btn-delete-small{color:#fff;background-color:#ef4444}.btn-delete-small:hover{background-color:#dc2626}.stocks-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.stock-card{background-color:#fff;border-radius:.5rem;transition:box-shadow .2s;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a}.stock-card:hover{box-shadow:0 20px 25px -5px #0000001a}.stock-card-low{border-left:4px solid #ef4444}.stock-card-content{padding:1.5rem}.stock-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.stock-card-title{color:#111827;font-size:1.125rem;font-weight:600}.stock-card-brand{color:#6b7280;margin-top:.25rem;font-size:.875rem}.stock-card-actions{gap:.5rem;display:flex}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.5rem;transition:background-color .2s}.btn-edit{color:#3b82f6}.btn-edit:hover{background-color:#eff6ff}.btn-delete{color:#ef4444}.btn-delete:hover{background-color:#fee2e2}.stock-card-description{color:#374151;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:1rem;font-size:.875rem;display:-webkit-box;overflow:hidden}.stock-card-details{margin-bottom:1rem;font-size:.875rem}.detail-row{justify-content:space-between;margin-bottom:.5rem;display:flex}.detail-label{color:#6b7280}.detail-value{font-weight:500}.notes{word-break:break-word;white-space:normal;max-width:200px;line-height:1.4}.stock-card-quantity{border-top:1px solid #e5e7eb;margin-bottom:1rem;padding-top:1rem}.quantity-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.quantity-value{color:#111827;font-size:1.5rem;font-weight:700}.quantity-low{color:#ef4444}.low-stock-alert{color:#ef4444;margin-bottom:.5rem;font-size:.75rem}.quantity-controls{gap:.5rem;display:flex}.quantity-input{border:1px solid #d1d5db;border-radius:.5rem;flex:1;padding:.5rem .75rem;font-size:.875rem}.quantity-input:focus{border-color:#3b82f6;outline:none}.btn-add{color:#fff;cursor:pointer;background-color:#10b981;border:none;border-radius:.5rem;align-items:center;gap:.25rem;padding:.5rem .75rem;transition:background-color .2s;display:flex}.btn-add:hover{background-color:#059669}.btn-remove{color:#fff;cursor:pointer;background-color:#eab308;border:none;border-radius:.5rem;align-items:center;gap:.25rem;padding:.5rem .75rem;transition:background-color .2s;display:flex}.btn-remove:hover{background-color:#ca8a04}.pagination-container{background:#fff;border-radius:.5rem;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem;display:flex;box-shadow:0 1px 3px #0000001a}.pagination-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #ddd;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af;transform:translateY(-1px)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f9fafb}.pagination-numbers{flex-wrap:wrap;gap:.25rem;display:flex}.pagination-number{cursor:pointer;color:#374151;text-align:center;background:#fff;border:1px solid #ddd;border-radius:.375rem;min-width:2.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s}.pagination-number:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af;transform:translateY(-1px)}.pagination-number.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.modal-overlay{z-index:50;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-container{background-color:#fff;border-radius:.5rem;width:100%;max-width:56rem;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-title{font-size:1.5rem;font-weight:700}.modal-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;font-size:1.5rem}.modal-close:hover{color:#6b7280}.modal-form{padding:1.5rem}.form-grid{grid-template-columns:repeat(1,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}@media (min-width:768px){.form-grid{grid-template-columns:repeat(2,1fr)}}.form-field,.form-field-full{grid-column:span 1}@media (min-width:768px){.form-field-full{grid-column:span 2}}.form-label{color:#374151;margin-bottom:.25rem;font-size:.875rem;font-weight:500;display:block}.form-input,.form-select,.form-textarea{border:1px solid #d1d5db;border-radius:.5rem;width:100%;padding:.5rem .75rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;outline:none}.field-hint{color:#9ca3af;margin-top:.25rem;font-size:.7rem;font-style:italic}.error-input{background-color:#fef2f2!important;border-color:#ef4444!important}.error-text{color:#ef4444;margin-top:.25rem;font-size:.75rem}.modal-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;padding-top:1rem;display:flex}.btn-cancel{color:#374151;cursor:pointer;background-color:#e5e7eb;border:none;border-radius:.5rem;padding:.5rem 1rem;transition:background-color .2s}.btn-cancel:hover{background-color:#d1d5db}.btn-submit{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:.5rem;padding:.5rem 1rem;transition:background-color .2s}.btn-submit:hover{background-color:#2563eb}.remove-modal{max-width:32rem}.btn-remove-submit{background-color:#ef4444}.btn-remove-submit:hover{background-color:#dc2626}.add-modal{max-width:32rem}.btn-add-submit{background-color:#10b981}.btn-add-submit:hover{background-color:#059669}.stock-info{background-color:#f3f4f6;border-radius:.5rem;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem;display:flex}.stock-info-label{color:#6b7280;font-size:.875rem;font-weight:500}.stock-info-value{color:#111827;font-size:.875rem;font-weight:600}.transaction-history-container{background-color:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.transaction-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.section-title{color:#111827;font-size:1.25rem;font-weight:600}.header-buttons{align-items:center;gap:.75rem;display:flex}.export-btn{color:#fff;cursor:pointer;background-color:#10b981;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s;display:flex}.export-btn:hover{background-color:#059669}.refresh-btn{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s;display:flex}.refresh-btn:hover:not(:disabled){background-color:#2563eb}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.transaction-filters{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.filter-group{flex-direction:column;gap:.25rem;display:flex}.filter-group label{color:#6b7280;font-size:.75rem;font-weight:500}.filter-group select,.filter-group input{border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem;font-size:.875rem}.search-icon-small{color:#9ca3af;font-size:.875rem;position:absolute;top:50%;left:.5rem;transform:translateY(-50%)}.search-input-small{padding-left:1.75rem}.date-input{min-width:140px}.checkbox-label{color:#374151;cursor:pointer;white-space:nowrap;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.checkbox-label input{cursor:pointer;width:1rem;height:1rem;margin:0}.transaction-summary{background-color:#f3f4f6;border-radius:.5rem;flex-wrap:wrap;gap:2rem;margin-bottom:1.5rem;padding:1rem;display:flex}.summary-stat{align-items:baseline;gap:.5rem;display:flex}.stat-label{color:#6b7280;font-size:.875rem}.stat-value{font-size:1.125rem;font-weight:600}.stat-add{color:#10b981}.stat-remove{color:#ef4444}.stat-new{color:#3b82f6}.stat-deleted{color:#ef4444}.transaction-table-container{overflow-x:auto}.transaction-table{border-collapse:collapse;width:100%}.transaction-table th{text-align:left;color:#374151;background-color:#f9fafb;border-bottom:2px solid #e5e7eb;padding:.75rem;font-size:.875rem;font-weight:600}.transaction-table td{border-bottom:1px solid #f3f4f6;padding:.75rem;font-size:.875rem}.transaction-row.add{background-color:#f0fdf4}.transaction-row.remove{background-color:#fef2f2}.transaction-row.new{background-color:#eff6ff}.transaction-row.deleted-row{opacity:.85;background-color:#fef2f2}.transaction-row.deleted-row:hover{opacity:1;background-color:#fee2e2}.part-number-cell{font-family:monospace;font-weight:500}.transaction-id-cell{color:#3b82f6;font-family:monospace;font-size:.8rem;font-weight:600}.stock-id-cell{color:#6b7280;font-family:monospace;font-size:.8rem;font-weight:500}.active-stock-id{color:#10b981;font-family:monospace;font-weight:600}.deleted-stock-id{color:#ef4444;font-family:monospace;font-weight:600}.reason-cell{word-break:break-word;max-width:250px}.deleted-text{color:#9ca3af;font-style:italic;text-decoration:line-through}.quantity-cell{font-weight:600}.quantity-cell.add{color:#10b981}.quantity-cell.remove{color:#ef4444}.quantity-cell.new{color:#3b82f6}.quantity-deleted{color:#9ca3af;text-decoration:line-through}.type-badge{border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.type-badge.add{color:#065f46;background-color:#d1fae5}.type-badge.remove{color:#991b1b;background-color:#fee2e2}.type-badge.new{color:#1e40af;background-color:#dbeafe}.type-badge.deleted{color:#991b1b;background-color:#fee2e2}.status-badge{white-space:nowrap;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.status-badge.active{color:#065f46;background-color:#d1fae5}.status-badge.deleted{color:#991b1b;background-color:#fee2e2}.tab-navigation{border-bottom:2px solid #e5e7eb;gap:.5rem;margin-bottom:2rem;padding-bottom:0;display:flex}.tab-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;position:relative}.tab-btn:hover,.tab-btn.active{color:#3b82f6}.tab-btn.active:after{content:"";background-color:#3b82f6;height:2px;position:absolute;bottom:-2px;left:0;right:0}.loading-container{flex-direction:column;justify-content:center;align-items:center;padding:3rem;display:flex}.spinner{border:4px solid #f3f3f3;border-top-color:#3b82f6;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:#666;margin-top:1rem;font-size:.875rem}.empty-state{text-align:center;background:#fff;border-radius:.5rem;margin-top:1rem;padding:3rem}.empty-text{color:#666;font-size:1rem}@media (max-width:768px){.actions-bar{flex-direction:column;gap:1rem}.search-section{flex-direction:column;width:100%}.action-buttons-group{justify-content:stretch;width:100%}.btn-export-all,.btn-export-current,.btn-add-new{flex:1;justify-content:center;padding:.5rem .75rem;font-size:.75rem}.quantity-controls-inline{flex-direction:column;align-items:flex-start}.quantity-input-small{width:100%}.stock-table th,.stock-table td{padding:.5rem .75rem}.header-content{text-align:center;flex-direction:column;gap:1rem}.tab-btn{padding:.5rem 1rem;font-size:.875rem}.transaction-filters{flex-direction:column}.filter-group,.date-input{width:100%}.transaction-summary{flex-direction:column;gap:.5rem}.pagination-container{flex-direction:column;align-items:stretch}.pagination-controls{justify-content:center}.pagination-numbers{order:2;justify-content:center}.pagination-btn:first-child{order:1}.pagination-btn:last-child{order:3}.pagination-number{min-width:2rem;padding:.375rem .5rem;font-size:.75rem}.search-info{flex-direction:column;align-items:stretch}.view-toggle{justify-content:center}.checkbox-label{white-space:normal}.stocks-grid{grid-template-columns:1fr}}@media (max-width:640px){.stocks-grid{grid-template-columns:1fr}}.detail-row-notes{align-items:flex-start!important}.notes-container{flex-direction:column;flex:1;gap:.25rem;display:flex}.note-line{color:#4b5563;word-break:break-word;white-space:normal;padding:.125rem 0;font-size:.75rem;line-height:1.4}.note-line:first-child{margin-top:0}.note-line:last-child{margin-bottom:0}.notes-container{max-height:120px;padding-right:.5rem;overflow-y:auto}.notes-container::-webkit-scrollbar{width:4px}.notes-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.notes-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.notes-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.detail-row{margin-bottom:.5rem;line-height:1.5;display:flex}.detail-label{color:#6b7280;min-width:80px;font-size:.8rem;font-weight:600}.detail-value{color:#1f2937;word-break:break-word;flex:1;font-size:.8rem}.detail-value.notes{margin:0;padding:0}.spin{animation:1s linear infinite spin}.per-page-select{cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem;font-size:.875rem}.per-page-select:hover{border-color:#cbd5e1}.pagination-container{border-top:1px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;display:flex}.pagination-info{color:#64748b;font-size:.875rem}.pagination-controls{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.pagination-btn{color:#334155;cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{gap:.25rem;display:flex}.pagination-number{color:#334155;cursor:pointer;text-align:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:.375rem;min-width:2.5rem;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.pagination-number:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1}.pagination-number.active{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.pagination-number:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.pagination-container{flex-direction:column;align-items:center}.pagination-controls{justify-content:center}.pagination-numbers{order:2}.pagination-btn:first-child{order:1}.pagination-btn:last-child{order:3}}
