*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#1e293b;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:Fira Code,Monaco,Cascadia Code,Roboto Mono,monospace}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.btn{border-radius:.5rem;font-size:.875rem;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:#3b82f6}.btn-primary:hover{background-color:#2563eb}.btn-secondary{background-color:#6b7280}.btn-secondary:hover{background-color:#4b5563}.btn-success{background-color:#10b981}.btn-success:hover{background-color:#059669}.btn-warning{background-color:#f59e0b;color:#fff}.btn-warning:hover{background-color:#d97706}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.card{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;overflow:hidden}.card-header{border-bottom:1px solid #e2e8f0}.card-body,.card-header{padding:1.5rem}.form-group{margin-bottom:1rem}.form-label{color:#374151;display:block;font-weight:500;margin-bottom:.5rem}.form-input{border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;padding:.75rem;transition:border-color .2s ease;width:100%}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;cursor:pointer;font-size:.875rem;padding:.75rem;width:100%}.table{border-collapse:collapse;width:100%}.table td,.table th{border-bottom:1px solid #e2e8f0;padding:.75rem;text-align:left}.table th{background-color:#f8fafc;color:#374151;font-weight:600}.status-badge{padding:.25rem .75rem}.status-pending{background-color:#fef3c7}.status-in-transit{background-color:#dbeafe}.status-delivered{background-color:#d1fae5}.status-sold{background-color:#e5e7eb;color:#374151}.loading{color:#6b7280;padding:2rem}.error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b}.error,.success{margin-bottom:1rem;padding:1rem}.success{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;color:#166534}.loading-screen{align-items:center;background:#f8fafc;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.loading-spinner{border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}.loading-screen p{font-size:14px;font-weight:500;margin:0}@media (max-width:768px){.container{padding:0 .5rem}.btn{font-size:.8rem;padding:.5rem 1rem}.card-body,.card-header{padding:1rem}.table td,.table th{font-size:.875rem;padding:.5rem}}.layout{background-color:#f8fafc}.layout,.sidebar{display:flex;height:100vh}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease;width:280px;z-index:1000}.sidebar-open{transform:translateX(0)}.sidebar-overlay{background:#00000080;inset:0;position:fixed;z-index:999}.sidebar-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:1.5rem}.logo,.sidebar-header{align-items:center;display:flex}.logo{gap:.75rem}.logo-icon{color:#3b82f6}.logo-text{color:#1e293b;font-size:1.25rem;font-weight:700}.sidebar-close{background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;padding:.5rem;transition:background-color .2s ease}.sidebar-close:hover{background-color:#f3f4f6}.sidebar-nav{flex:1 1;padding:1rem 0}.nav-item{align-items:center;color:#6b7280;display:flex;font-weight:500;gap:.75rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.nav-item:hover{background-color:#f8fafc;color:#374151}.nav-item-active{background-color:#eff6ff;border-right:3px solid #3b82f6;color:#3b82f6}.sidebar-footer{border-top:1px solid #e2e8f0;padding:1.5rem}.user-info{gap:.75rem}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background-color:#3b82f6;border-radius:50%;color:#fff;height:2rem;justify-content:center;width:2rem}.user-details{flex:1 1}.user-name{color:#1e293b;font-size:.875rem;font-weight:600}.user-role{color:#6b7280;font-size:.75rem}.main-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.header{background:#fff;border-bottom:1px solid #e2e8f0;height:72px;justify-content:space-between;padding:1rem 1.5rem}.header,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.menu-button{background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;padding:.5rem;transition:background-color .2s ease}.menu-button:hover{background-color:#f3f4f6}.page-title{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.header-right{align-items:center;display:flex;gap:1rem}.notification-button,.settings-button{background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;padding:.5rem;position:relative;transition:background-color .2s ease}.notification-button:hover,.settings-button:hover{background-color:#f3f4f6}.notification-badge{align-items:center;background-color:#ef4444;border-radius:9999px;color:#fff;display:flex;font-size:.75rem;height:1.25rem;justify-content:center;min-width:1.25rem;padding:.125rem .375rem;position:absolute;right:0;top:0}.blockchain-status{align-items:center;background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:.5rem;display:flex;gap:.5rem;padding:.5rem 1rem}.status-indicator{border-radius:50%;height:.5rem;width:.5rem}.status-connected{background-color:#10b981}.status-text{color:#166534;font-size:.875rem;font-weight:500}.content{flex:1 1;overflow-y:auto;padding:1.5rem}.mobile-only{display:none}@media (max-width:768px){.sidebar{max-width:320px;width:100%}.mobile-only{display:block}.header{padding:1rem}.page-title{font-size:1.25rem}.content{padding:1rem}.blockchain-status{display:none}}.user-menu-container{position:relative}.user-menu-trigger{align-items:center;background:none;border:none;border-radius:.5rem;cursor:pointer;display:flex;gap:.5rem;padding:.5rem;transition:background-color .2s}.user-menu-trigger:hover{background-color:#f3f4f6}.user-avatar-small{align-items:center;background-color:#667eea;border-radius:50%;color:#fff;display:flex;height:2rem;justify-content:center;width:2rem}.user-name-header{color:#374151;font-size:.875rem;font-weight:500}.user-menu-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:.5rem;min-width:200px;position:absolute;right:0;top:100%;z-index:50}.user-menu-header{padding:1rem}.user-info-header{display:flex;flex-direction:column;gap:.25rem}.user-info-header strong{color:#111827;font-size:.875rem}.user-info-header small{color:#6b7280;font-size:.75rem}.user-menu-divider{background-color:#e5e7eb;height:1px;margin:.5rem 0}.user-menu-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s;width:100%}.user-menu-item:hover{background-color:#f9fafb}.user-menu-item.logout{color:#dc2626}.user-menu-item.logout:hover{background-color:#fef2f2}.user-status{margin-top:4px}.status-verified{color:#059669;font-size:.7rem;font-weight:500}.status-pending{color:#d97706;font-size:.7rem;font-weight:500}@media (min-width:769px){.sidebar{position:static;transform:translateX(0)}.menu-button,.sidebar-overlay{display:none}}@media (max-width:768px){.user-name-header{display:none}.user-menu-dropdown{left:auto;min-width:180px;right:-1rem}}.verification-banner{background:linear-gradient(135deg,#fef3c7,#fcd34d);border:1px solid #f59e0b;border-radius:.75rem;margin-bottom:1.5rem;overflow:hidden}.banner-content{align-items:flex-start;display:flex;gap:1rem;padding:1.5rem}.banner-icon{color:#d97706;flex-shrink:0;margin-top:.25rem}.banner-text{flex:1 1}.banner-text h3{color:#92400e;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.banner-text p{color:#78350f;line-height:1.5;margin:0 0 1rem}.contact-info{display:flex;flex-wrap:wrap;gap:1rem}.contact-item{align-items:center;color:#78350f;display:flex;font-size:.875rem;gap:.5rem}.contact-item svg{color:#d97706}.banner-actions{flex-shrink:0}.contact-button{background:#d97706;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.contact-button:hover{background:#b45309}@media (max-width:768px){.banner-content{flex-direction:column;gap:1rem}.banner-actions{align-self:stretch}.contact-button{width:100%}.contact-info{flex-direction:column;gap:.5rem}}.dashboard{padding:0}.welcome-section{margin-bottom:2rem}.welcome-section h2{color:#1e293b;font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.welcome-section p{color:#64748b;font-size:1rem}.stats-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem}.stat-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.stat-icon{border-radius:.75rem;color:#fff;height:3rem;width:3rem}.stat-icon-blue{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.stat-icon-orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon-green{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-value{flex:1 1;text-align:right}.stat-number{color:#1e293b;display:block;font-size:2rem;font-weight:700;line-height:1}.stat-change{align-items:center;display:inline-flex;font-size:.875rem;font-weight:500;gap:.25rem;margin-top:.5rem}.stat-change-positive{color:#059669}.stat-change-negative{color:#dc2626}.stat-title{color:#64748b;font-size:.875rem;font-weight:500}.charts-section{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:2fr 1fr;margin-bottom:2rem}.chart-card{border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;overflow:hidden}.chart-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem}.chart-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.chart-legend{display:flex;gap:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border-radius:50%;height:.75rem;width:.75rem}.legend-item span{color:#64748b;font-size:.875rem}.chart-container{padding:1rem 1.5rem 1.5rem}.activity-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;overflow:hidden}.activity-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem}.activity-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.view-all-btn{background:none;border:none;border-radius:.375rem;color:#3b82f6;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem;transition:background-color .2s ease}.view-all-btn:hover{background-color:#f1f5f9}.activity-list{max-height:400px;overflow-y:auto;padding:1rem}.activity-item{align-items:flex-start;border-radius:.5rem;display:flex;gap:.75rem;padding:.75rem;transition:background-color .2s ease}.activity-item:hover{background-color:#f8fafc}.activity-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:2rem;justify-content:center;width:2rem}.activity-icon-blue{background-color:#3b82f6}.activity-icon-green{background-color:#10b981}.activity-icon-purple{background-color:#8b5cf6}.activity-icon-orange{background-color:#f59e0b}.activity-content{flex:1 1;min-width:0}.activity-message{color:#374151;font-size:.875rem;line-height:1.4;margin:0 0 .25rem}.activity-timestamp{color:#64748b;font-size:.75rem}.quick-actions{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem}.quick-actions h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.actions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem;text-decoration:none;transition:all .2s ease}.action-btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.action-btn-primary:hover{box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.action-btn-secondary{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.action-btn-secondary:hover{box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.action-btn-tertiary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.action-btn-tertiary:hover{box-shadow:0 4px 12px #f59e0b66;transform:translateY(-1px)}@media (max-width:1024px){.charts-section{grid-template-columns:1fr}.chart-header{align-items:flex-start;flex-direction:column;gap:1rem}}@media (max-width:768px){.stats-grid{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1rem}.stat-header{align-items:flex-start;flex-direction:column;gap:1rem}.stat-value{text-align:left}.welcome-section h2{font-size:1.5rem}.actions-grid{grid-template-columns:1fr}}.receive-goods{background:#f8f9fa;margin:0 auto;max-width:100%;min-height:calc(100vh - 80px)}.alert-success{background:#d4edda}.scanner-section{margin-bottom:30px}.scanner-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px;text-align:center}.scanner-header{margin-bottom:25px}.scanner-header h3{color:#2c3e50;font-size:1.5rem;margin:15px 0 8px}.scanner-header p{color:#7f8c8d;margin:0}.scanner-input{margin:0 auto;max-width:600px}.input-group{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:4px;transition:all .3s ease}.input-group:focus-within{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.input-icon{color:#7f8c8d;margin:0 12px}.scan-input{background:#0000;border:none;flex:1 1;font-size:1rem;outline:none;padding:12px 8px}.scan-btn{border-radius:6px;margin:0;padding:12px 24px}.btn{font-size:1rem}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-2px)}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.btn-success{background:#27ae60}.btn-success:hover:not(:disabled){background:#229954;transform:translateY(-2px)}.btn-outline{background:#0000;border:2px solid #3498db;color:#3498db}.btn-outline:hover{background:#3498db;color:#fff}.btn:disabled{transform:none}.shipment-details{margin-bottom:30px}.details-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.details-header{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.details-header h3{align-items:center;display:flex;font-size:1.3rem;gap:10px;margin:0}.shipment-id{background:#fff3;border-radius:20px;font-size:.9rem;padding:6px 12px}.details-content{padding:30px}.info-section,.notes-section,.products-section{margin-bottom:25px}.info-section h4,.notes-section h4,.products-section h4{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:1.1rem;margin-bottom:15px;padding-bottom:8px}.info-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{border-bottom:1px solid #f1f2f6}.info-item .value{font-weight:600}.info-item .value.highlight{color:#27ae60;font-size:1.1rem}.products-table{border:1px solid #e9ecef;border-radius:8px;overflow-x:auto}.products-table table{border-collapse:collapse;font-size:.95rem;width:100%}.products-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#2c3e50;font-weight:600;padding:12px 16px;text-align:left}.products-table td{border-bottom:1px solid #f1f2f6;color:#2c3e50;padding:12px 16px}.products-table tbody tr:hover{background:#f8f9fa}.no-products{color:#6c757d;font-style:italic;padding:20px!important;text-align:center}.batch-code{background:#e3f2fd;border-radius:4px;color:#1976d2;font-family:Courier New,monospace;font-weight:600;padding:4px 8px}.quantity{color:#27ae60}.expiry{color:#f39c12;font-weight:500}.manufacturer{color:#7f8c8d;font-style:italic}.notes-content{align-items:flex-start;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;display:flex;gap:10px;line-height:1.5;padding:15px}.details-actions{display:flex;gap:15px;justify-content:flex-end;padding:0 30px 30px}.pending-shipments{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.pending-header{margin-bottom:25px}.pending-header h3{align-items:center;color:#2c3e50;display:flex;font-size:1.3rem;gap:10px;margin:0}.pending-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.no-pending{color:#7f8c8d;grid-column:1/-1;padding:60px 20px;text-align:center}.no-pending h4{color:#5a6c7d;margin-bottom:10px}.no-pending p{font-size:1rem;line-height:1.5}.pending-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:20px;transition:all .3s ease}.pending-card:hover{border-color:#3498db;box-shadow:0 4px 15px #3498db1a;transform:translateY(-2px)}.pending-header-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.pending-card .shipment-id{background:#3498db;border-radius:15px;color:#fff;font-size:.85rem;font-weight:600;padding:4px 10px}.tracking-code{color:#7f8c8d;font-family:Courier New,monospace;font-size:.9rem}.pending-content{margin-bottom:15px}.from-info{color:#2c3e50;margin-bottom:8px}.expected-date{color:#f39c12;font-weight:500;margin-bottom:5px}.products-count{color:#7f8c8d;margin-bottom:5px}.total-value{color:#27ae60;font-size:1.1rem;font-weight:600}.pending-actions{display:flex;gap:10px}@media (max-width:768px){.receive-goods{padding:10px}.scanner-card{padding:20px}.input-group{flex-direction:column;gap:10px}.scan-input{text-align:center;width:100%}.details-content{padding:20px}.info-grid{grid-template-columns:1fr}.details-actions{flex-direction:column;padding:0 20px 20px}.pending-grid{grid-template-columns:1fr}.details-header{flex-direction:column;gap:10px;padding:15px 20px;text-align:center}}.batch-management{padding:0}.page-header{align-items:flex-start;gap:1rem;margin-bottom:2rem}.header-content h1{color:#1e293b;font-size:1.875rem;font-weight:700;margin:0 0 .5rem}.header-content p{color:#64748b;margin:0}.filters-section{gap:1rem;margin-bottom:1.5rem}.search-box{background:#fff;border-radius:.5rem;gap:.75rem;padding:.75rem 1rem}.search-box svg{flex-shrink:0}.search-box input{background:none;font-size:.875rem}.search-box input::placeholder{color:#94a3b8}.filter-group{background:#fff;border-radius:.5rem;gap:.75rem;padding:.75rem 1rem}.filter-group select{background:none;font-size:.875rem}.summary-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;display:flex;gap:1rem;padding:1.5rem}.stat-icon{border-radius:.5rem;color:#64748b;flex-shrink:0;height:2.5rem;width:2.5rem}.stat-icon.stat-success{background:#dcfce7;color:#16a34a}.stat-icon.stat-warning{background:#fef3c7;color:#d97706}.stat-icon.stat-danger{background:#fee2e2;color:#dc2626}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem}.stat-label{font-size:.875rem}.table-container{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;overflow:hidden}.batches-table{border-collapse:collapse;width:100%}.batches-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#374151;font-size:.875rem;font-weight:600;padding:1rem;text-align:left}.batches-table td{border-bottom:1px solid #f1f5f9;padding:1rem;vertical-align:top}.batches-table tr:last-child td{border-bottom:none}.batches-table tr:hover{background:#f8fafc}.batch-id{display:flex;flex-direction:column;gap:.25rem}.batch-id strong{color:#1e293b;font-weight:600}.qr-code{color:#64748b;font-family:Fira Code,monospace;font-size:.75rem}.drug-info{gap:.25rem}.drug-info strong{font-weight:600}.ingredient{color:#64748b;font-size:.875rem}.quantity-info{align-items:baseline;display:flex;gap:.25rem}.quantity-info .available{color:#1e293b;font-weight:600}.quantity-info .total{color:#64748b;font-size:.875rem}.expiry-info{display:flex;flex-direction:column;gap:.25rem}.expiry-info .date{color:#1e293b;font-weight:500}.days-left{color:#64748b;font-size:.75rem}.days-left.warning{color:#d97706;font-weight:500}.status-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;gap:.375rem;padding:.375rem .75rem}.status-available{background:#dcfce7;color:#166534}.status-out-of-stock{background:#fee2e2;color:#991b1b}.status-expiring{background:#fef3c7;color:#92400e}.status-in-transit{background:#dbeafe;color:#1e40af}.action-buttons{display:flex;gap:.5rem}.btn-icon{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:.375rem;cursor:pointer;display:flex;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.btn-icon:hover{background:#f8fafc}.btn-icon:disabled{cursor:not-allowed;opacity:.5}.btn-view{color:#3b82f6}.btn-view:hover{background:#eff6ff;border-color:#3b82f6}.btn-ship{color:#10b981}.btn-ship:hover{background:#ecfdf5;border-color:#10b981}.empty-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem;text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state h3{color:#374151;font-size:1.125rem;margin:0 0 .5rem}.empty-state p{font-size:.875rem;margin:0}.modal-overlay{background:#00000080;inset:0;padding:1rem}.modal-content{border-radius:.75rem;display:flex;flex-direction:column;max-width:800px;overflow:hidden}.modal-header{border-bottom:1px solid #e2e8f0;padding:1.5rem}.modal-header h2{color:#1e293b;font-size:1.25rem;font-weight:600}.modal-close{align-items:center;background:none;border:none;border-radius:.375rem;color:#64748b;cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;transition:background-color .2s ease;width:2rem}.modal-close:hover{background:#f1f5f9}.modal-body{flex:1 1;overflow-y:auto;padding:1.5rem}.detail-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.detail-group{display:flex;flex-direction:column;gap:1rem}.detail-group h3{border-bottom:1px solid #e2e8f0;color:#374151;font-size:1rem;font-weight:600;margin:0;padding-bottom:.5rem}.detail-item{gap:1rem;justify-content:space-between}.detail-item label{color:#64748b;font-size:.875rem;font-weight:500;min-width:120px}.detail-item span{color:#1e293b;font-weight:500}.qr-code-display{background:#f1f5f9;border-radius:.25rem;font-family:Fira Code,monospace!important;font-size:.875rem!important;padding:.25rem .5rem}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.loading{align-items:center;color:#64748b;display:flex;font-size:1.125rem;gap:.75rem;justify-content:center;padding:4rem 2rem}@media (max-width:768px){.filters-section{flex-direction:column}.search-box{min-width:auto}.summary-stats{grid-template-columns:repeat(2,1fr)}.batches-table{font-size:.875rem}.batches-table td,.batches-table th{padding:.75rem .5rem}.detail-grid{gap:1.5rem;grid-template-columns:1fr}.modal-content{margin:.5rem;max-width:calc(100vw - 1rem)}.detail-item{align-items:flex-start;flex-direction:column;gap:.5rem}.detail-item label{min-width:auto}}.create-shipment{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:calc(100vh - 80px);padding:16px}.page-header{align-items:flex-end;border-bottom:1px solid #e5e7eb;margin-bottom:20px;padding:12px 0 20px}.page-header .header-content h1{color:#0f172a;font-size:28px;font-weight:700;margin:0 0 6px}.page-header .header-content p{color:#64748b;margin:0}.step-indicator{background:linear-gradient(135deg,#f8fafc,#eef2ff);border-radius:12px;gap:16px;justify-content:center;margin-bottom:20px;padding:16px}.step-indicator,.step-item{align-items:center;display:flex}.step-item{gap:8px}.step-circle{align-items:center;background:#e2e8f0;border-radius:50%;color:#475569;display:flex;font-weight:600;height:32px;justify-content:center;width:32px}.step-circle.active{background:#3b82f6;box-shadow:0 0 0 3px #3b82f626;color:#fff}.step-label{color:#64748b;font-weight:500}.step-label.active{color:#1f2937}.step-arrow{color:#cbd5e1}.form-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 20px #0206170a}.step-content{padding:20px}.step-content h2{color:#0f172a;font-size:20px;margin:0 0 16px}.section-header{border-bottom:2px solid #f1f5f9;color:#0f172a;font-weight:600;gap:8px;margin-bottom:16px;padding-bottom:10px}.batch-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.batch-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:14px;position:relative;transition:border-color .2s,box-shadow .2s,transform .1s}.batch-card:hover{border-color:#93c5fd;box-shadow:0 10px 24px #0206170f;transform:translateY(-1px)}.batch-card.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.batch-card.expired{background:#fef2f2;border-color:#fca5a5}.batch-card.expired:hover{border-color:#f87171}.expired-badge{align-items:center;background:#ef4444;border-radius:6px;color:#fff;display:flex;font-size:11px;font-weight:600;gap:4px;padding:4px 8px;position:absolute;right:8px;top:8px;z-index:1}.expired-text{color:#dc2626!important;font-weight:600}.batch-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.batch-header strong{color:#0f172a}.batch-id{color:#64748b;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.batch-details p{color:#475569;font-size:14px;margin:4px 0}.batch-quantity{font-weight:600;margin-top:8px}.batch-quantity .available{color:#059669}.batch-quantity .total{color:#64748b;font-weight:500}.quantity-input{margin-top:16px}.quantity-input label{color:#0f172a;font-weight:600}.quantity-input .input-group{align-items:center;display:flex;gap:8px;margin-top:8px}.quantity-input input{border:1px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:16px;padding:10px 12px}.help-text,.quantity-input .unit{color:#64748b}.help-text{font-size:13px;margin-top:6px}.error-message{color:#991b1b;display:inline-flex;gap:6px;margin-top:10px;padding:8px 10px}.pharmacy-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.pharmacy-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:14px;transition:box-shadow .2s,border-color .2s}.pharmacy-card:hover{border-color:#93c5fd;box-shadow:0 10px 24px #0206170f}.pharmacy-card.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.pharmacy-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.pharmacy-header h3{color:#0f172a;font-size:16px;margin:0}.pharmacy-id{color:#64748b;font-size:12px}.pharmacy-details{grid-gap:4px;color:#475569;display:grid;font-size:14px;gap:4px;grid-template-columns:1fr}.detail-item{align-items:center;display:flex;gap:6px}.wallet-address{color:#334155;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;margin-top:8px;overflow-wrap:anywhere}.delivery-details{margin-top:16px}.delivery-details h3{color:#0f172a;font-size:16px;margin:0 0 10px}.form-row{grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.form-group{gap:6px}.form-group label{color:#0f172a;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid #e5e7eb;border-radius:8px;font-size:14px;padding:10px 12px}.form-group textarea{min-height:80px;resize:vertical}.input-group{gap:8px}.btn-generate{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:10px 12px}.btn-generate:hover{background:#eff6ff;border-color:#bfdbfe}.confirmation-summary{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr}.summary-section h3{color:#0f172a;font-size:16px;margin:0 0 8px}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px}.summary-item{grid-gap:8px;border-bottom:1px dashed #e5e7eb;display:grid;gap:8px;grid-template-columns:160px 1fr;padding:6px 0}.summary-item:last-child{border-bottom:none}.summary-item label{color:#64748b}.summary-item .blockchain-id{background:#eff6ff;border-radius:4px;color:#3b82f6;font-family:Courier New,monospace;font-weight:600;padding:4px 8px}.form-navigation{align-items:center;background:#fafafa;border-bottom-left-radius:12px;border-bottom-right-radius:12px;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:14px 20px}.btn{border:1px solid #0000;font-weight:600}.btn-primary{background:#3b82f6}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#e5e7eb;color:#0f172a}.btn-secondary:hover{background:#d1d5db}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.loading-spinner{animation:spin 1s linear infinite}@media (max-width:768px){.step-indicator{align-items:stretch;flex-direction:column;gap:10px}.step-item{justify-content:center}.summary-item{grid-template-columns:1fr}}.export-management{margin:0 auto;max-width:1400px;padding:24px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{color:#1e293b;font-weight:700;margin:0}.page-header p{color:#64748b;margin:4px 0 0}.btn-refresh{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.btn-refresh:hover{background:#2563eb;transform:translateY(-1px)}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:20px}.stat-card.total{border-left-color:#3b82f6}.stat-card.pending{border-left-color:#f59e0b}.stat-card.in-transit{border-left-color:#8b5cf6}.stat-card.delivered{border-left-color:#10b981}.stat-icon{align-items:center;background:#f1f5f9;border-radius:12px;color:#3b82f6;display:flex;height:48px;justify-content:center;width:48px}.stat-card.pending .stat-icon{background:#fef3c7;color:#f59e0b}.stat-card.in-transit .stat-icon{background:#ede9fe;color:#8b5cf6}.stat-card.delivered .stat-icon{background:#d1fae5;color:#10b981}.stat-content{display:flex;flex-direction:column}.stat-label{color:#64748b;font-size:14px;margin-bottom:4px}.stat-value{color:#1e293b;font-size:28px;font-weight:700}.filters-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.search-box{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex:1 1;gap:12px;min-width:300px;padding:10px 16px}.search-box svg{color:#64748b}.search-box input{background:#0000;border:none;color:#1e293b;flex:1 1;font-size:14px;outline:none}.filter-group{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;gap:8px;padding:10px 16px}.filter-group svg{color:#64748b}.filter-group select{background:#0000;border:none;color:#1e293b;cursor:pointer;font-size:14px;outline:none}.date-range{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:8px;padding:10px 16px}.date-range input{background:#0000;border:none;color:#1e293b;cursor:pointer;font-size:14px;outline:none}.date-range span{color:#64748b;font-size:14px}.shipments-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.shipments-table{border-collapse:collapse;width:100%}.shipments-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.shipments-table th{color:#64748b;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.shipments-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .2s}.shipments-table tbody tr:hover{background:#f8fafc}.shipments-table td{color:#1e293b;font-size:14px;padding:16px}.shipment-code{background:#f1f5f9;border-radius:4px;color:#3b82f6;font-family:Courier New,monospace;font-size:13px;font-weight:600;padding:4px 8px}.drug-info{display:flex;flex-direction:column;gap:4px}.drug-info strong{color:#1e293b}.drug-info small{color:#64748b;font-size:12px}.batch-number{background:#fef3c7;border-radius:4px;color:#92400e;font-family:Courier New,monospace;font-size:13px;font-weight:600;padding:4px 8px}.quantity{color:#1e293b;font-weight:600}.company-info{align-items:center;display:flex;gap:6px}.company-info svg{color:#64748b}.status-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.status-pending{background:#fef3c7;color:#92400e}.status-in-transit{background:#ede9fe;color:#6b21a8}.status-delivered{background:#d1fae5;color:#065f46}.status-cancelled{background:#fee2e2;color:#991b1b}.status-unknown{background:#f1f5f9;color:#64748b}.btn-action{align-items:center;background:#f1f5f9;border:none;border-radius:6px;color:#3b82f6;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s}.btn-action:hover{background:#3b82f6;color:#fff;transform:translateY(-1px)}.empty-state,.loading-state{align-items:center;color:#64748b;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.spinner{border:4px solid #f1f5f9;border-top-color:#3b82f6;height:40px;margin-bottom:16px;width:40px}.empty-state svg{color:#cbd5e1;margin-bottom:16px}.empty-state p{color:#64748b;font-size:16px}@media (max-width:768px){.export-management{padding:16px}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.stats-grid{grid-template-columns:1fr}.filters-section{flex-direction:column}.date-range,.filter-group,.search-box{width:100%}.shipments-table-container{overflow-x:auto}.shipments-table{min-width:1000px}}.shipment-tracking{background:#f8f9fa;margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px)}.shipment-header{align-items:center;display:flex;justify-content:space-between}.loading-container{align-items:center;color:#7f8c8d;display:flex;flex-direction:column;height:300px;justify-content:center}.alert{font-weight:500;gap:10px;margin-bottom:20px;padding:15px}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.controls-section{align-items:center;display:flex;flex:1 1;gap:10px;margin-bottom:10px;width:100%}.controls-section .search-box{flex:1 1;min-width:300px;position:relative;width:60%}.controls-section .filter-section{width:20%}.controls-section .refresh-button{width:10%}.shipment-details{display:flex;flex-direction:column;gap:8px}.search-icon{color:#7f8c8d;left:12px;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.search-input{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:0 0 12px 45px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.filter-box{min-width:200px;position:relative}.filter-icon{color:#7f8c8d;left:12px;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.filter-select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:1rem;padding:12px 12px 12px 45px;transition:all .3s ease;width:100%}.filter-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.shipments-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.shipment-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden;padding:15px;transition:all .3s ease}.shipment-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.card-header{align-items:center;display:flex;justify-content:space-between;padding:20px 20px 0}.shipment-id{color:#2c3e50;font-size:1.1rem;gap:8px}.shipment-header .status-badge,.shipment-id{align-items:center;display:flex;font-weight:600}.shipment-header .status-badge{border-radius:20px;font-size:.85rem;gap:6px;padding:6px 12px;text-transform:uppercase}.status-pending{background:#fff3cd;color:#856404}.status-transit{background:#cce5ff;color:#06c}.status-delivered{background:#d4edda;color:#155724}.status-unknown{background:#f8d7da;color:#721c24}.status-icon{height:16px;width:16px}.card-content{padding:20px}.info-row{align-items:flex-start;border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:8px 0}.info-row:last-child{border-bottom:none}.info-row .label{color:#7f8c8d;flex:0 0 auto;font-weight:500;margin-right:10px}.info-row .value{align-items:center;color:#2c3e50;display:flex;flex:1 1;font-weight:500;gap:6px;justify-content:flex-end;text-align:right}.info-row .value.delivered{color:#27ae60;font-weight:600}.card-actions{display:flex;gap:10px;padding:0 20px 20px}.btn{border-radius:8px;flex:1 1;font-size:.9rem;gap:6px;justify-content:center;padding:10px 16px;transition:all .3s ease}.btn-primary{background:#3498db}.btn-primary:hover{background:#2980b9;transform:translateY(-1px)}.no-data{color:#7f8c8d;grid-column:1/-1;padding:60px 20px;text-align:center}.no-data-icon{margin-bottom:20px;opacity:.5}.no-data h3{color:#5a6c7d;margin-bottom:10px}.no-data p{font-size:1rem;line-height:1.5}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#2c3e50;font-size:1.3rem;margin:0}.close-button{align-items:center;background:none;border:none;color:#7f8c8d;cursor:pointer;display:flex;font-size:2rem;height:30px;justify-content:center;line-height:1;padding:0;width:30px}.close-button:hover{color:#e74c3c}.modal-body{padding:20px}.tracking-info .info-section{margin-bottom:30px}.tracking-info .info-section h3{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:1.1rem;margin-bottom:15px;padding-bottom:8px}.info-grid{grid-gap:12px;display:grid;gap:12px}.info-item{align-items:center;border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:10px 0}.info-item:last-child{border-bottom:none}.info-item .label{color:#7f8c8d;font-weight:500}.info-item .value{align-items:center;color:#2c3e50;display:flex;font-weight:500;gap:6px}.timeline{padding-left:30px;position:relative}.timeline:before{background:#e9ecef;bottom:0;content:"";left:10px;position:absolute;top:0;width:2px}.timeline-item{margin-bottom:25px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-icon{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:50%;display:flex;height:20px;justify-content:center;left:-25px;position:absolute;top:0;width:20px;z-index:2}.timeline-item.completed .timeline-icon{background:#27ae60;border-color:#27ae60;color:#fff}.timeline-content{background:#f8f9fa;border-left:3px solid #e9ecef;border-radius:8px;padding:15px}.timeline-item.completed .timeline-content{border-left-color:#27ae60}.timeline-title{color:#2c3e50;font-weight:600;margin-bottom:5px}.timeline-date{color:#7f8c8d;font-size:.9rem;margin-bottom:3px}.timeline-location{color:#5a6c7d;font-size:.9rem}@media (max-width:768px){.shipment-tracking{padding:10px}.shipments-grid{grid-template-columns:1fr}.controls{flex-direction:column}.filter-box,.search-box{min-width:auto}.modal-overlay{padding:10px}.modal-content{max-height:95vh}.card-header{gap:10px}.card-header,.info-row{align-items:flex-start;flex-direction:column}.info-row{gap:5px}.info-row .value{justify-content:flex-start}}.batch-id-highlight{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;border-radius:8px;margin-bottom:10px;padding:12px 16px}.batch-id-highlight strong{color:#2e7d32;display:block;margin-bottom:8px}.batch-id-value{background:#fff;border-radius:6px;color:#1b5e20;display:inline-block;font-family:Courier New,monospace;font-size:1.3rem;font-weight:700;margin-right:10px;padding:8px 12px;word-break:break-all}.copy-btn{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;padding:6px 12px;transition:background .2s}.copy-btn:hover{background:#388e3c}.batch-id-note{background:#fff3e0;border:1px solid #ffb74d;border-radius:6px;color:#e65100;font-size:.9rem;line-height:1.5;margin-top:12px;padding:10px 14px}.batch-id-note strong{color:#bf360c}.batch-id-mini{background:#e8f5e9;border-radius:4px;color:#2e7d32;font-size:.85rem;margin:4px 0;padding:4px 8px}.batch-id-mini strong{color:#1b5e20;font-family:Courier New,monospace}.reports{background:#f8f9fa;margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px);padding:20px}.page-header{margin-bottom:30px}.page-header h1{color:#2c3e50;font-size:2rem;margin-bottom:8px}.page-icon{color:#3498db}.page-header p{color:#7f8c8d;font-size:1.1rem}.error-container,.loading-container{align-items:center;color:#7f8c8d;display:flex;flex-direction:column;height:300px;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.controls{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:30px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{color:#555;font-size:.9rem;font-weight:500}.period-select,.report-select{background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:1rem;min-width:150px;padding:10px 12px}.period-select:focus,.report-select:focus{border-color:#3498db;outline:none}.export-btn{align-items:center;background:#27ae60;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:8px;margin-left:auto;padding:10px 20px;transition:all .3s ease}.export-btn:hover{background:#229954;transform:translateY(-2px)}.metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:30px}.metric-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;gap:20px;padding:24px;transition:all .3s ease}.metric-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.metric-icon{align-items:center;border-radius:12px;color:#fff;display:flex;height:60px;justify-content:center;width:60px}.metric-icon.batches{background:linear-gradient(135deg,#667eea,#764ba2)}.metric-icon.shipments{background:linear-gradient(135deg,#f093fb,#f5576c)}.metric-icon.delivered{background:linear-gradient(135deg,#4facfe,#00f2fe)}.metric-icon.value{background:linear-gradient(135deg,#43e97b,#38f9d7)}.metric-content{flex:1 1}.metric-value{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:4px}.metric-label{color:#7f8c8d;font-size:1rem;margin-bottom:8px}.metric-change{font-size:.9rem;font-weight:500}.metric-change.positive{color:#27ae60}.metric-change.negative{color:#e74c3c}.charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr;margin-bottom:30px}.chart-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:24px}.chart-header{margin-bottom:20px}.chart-header h3{color:#2c3e50;font-size:1.2rem;margin-bottom:4px}.chart-header p{color:#7f8c8d;font-size:.9rem;margin:0}.chart-container{width:100%}.table-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:24px}.table-header{margin-bottom:20px}.table-header h3{color:#2c3e50;font-size:1.2rem;margin-bottom:4px}.table-header p{color:#7f8c8d;font-size:.9rem;margin:0}.table-container{overflow-x:auto}.data-table{border-collapse:collapse;font-size:.95rem;width:100%}.data-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;font-weight:600;text-align:left}.data-table td,.data-table th{color:#2c3e50;padding:12px 16px}.data-table td{border-bottom:1px solid #f1f2f6}.data-table tbody tr:hover{background:#f8f9fa}.product-name{color:#2c3e50;font-weight:500}.progress-bar{background:#e9ecef;border-radius:20px;height:20px;min-width:100px;overflow:hidden;position:relative}.progress-fill{background:linear-gradient(90deg,#3498db,#2980b9);border-radius:20px;height:100%;transition:width .3s ease}.progress-text{color:#fff;font-size:.8rem;font-weight:600;left:50%;position:absolute;text-shadow:0 1px 2px #0000004d;top:50%;transform:translate(-50%,-50%)}.performance-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.performance-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;gap:20px;padding:24px;transition:all .3s ease}.performance-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.performance-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;height:60px;justify-content:center;width:60px}.performance-content{flex:1 1}.performance-value{color:#2c3e50;font-size:1.8rem;font-weight:700;margin-bottom:4px}.performance-label{color:#7f8c8d;font-size:.95rem;line-height:1.3}@media (max-width:1200px){.charts-grid{grid-template-columns:1fr}}@media (max-width:768px){.reports{padding:10px}.metrics-grid,.performance-grid{grid-template-columns:1fr}.controls{align-items:stretch;flex-direction:column}.export-btn{margin-left:0;margin-top:10px}.metric-card,.performance-card{padding:16px}.metric-value{font-size:1.5rem}.performance-value{font-size:1.4rem}.chart-card,.table-card{padding:16px}}.login-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-container{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:32px;text-align:center}.login-logo{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;display:inline-flex;height:80px;justify-content:center;margin-bottom:16px;width:80px}.login-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.login-header p{color:#6b7280;font-size:14px;margin:0}.login-form{margin-bottom:32px}.input-group input{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px 12px 12px 44px;transition:all .2s;width:100%}.input-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.input-group input.error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.input-group input:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:8px;padding:14px;transition:all .2s;width:100%}.login-button:hover:not(:disabled){box-shadow:0 10px 25px -5px #667eea4d;transform:translateY(-1px)}.login-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.demo-section{border-top:1px solid #e5e7eb;margin-bottom:24px;padding-top:24px;text-align:center}.demo-section p{color:#6b7280;font-size:14px;margin-bottom:16px}.demo-buttons{display:flex;flex-wrap:wrap;gap:12px}.demo-button{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;min-width:140px;padding:10px 16px;transition:all .2s}.demo-button:hover:not(:disabled){background:#f8faff;border-color:#667eea;color:#667eea}.demo-button:disabled{cursor:not-allowed;opacity:.6}.demo-button.distributor:hover:not(:disabled){background:#f0fdf4;border-color:#059669;color:#059669}.demo-button.manufacturer:hover:not(:disabled){background:#fef2f2;border-color:#dc2626;color:#dc2626}.login-footer{border-top:1px solid #e5e7eb;padding-top:24px;text-align:center}.login-footer p{color:#6b7280;font-size:14px;margin:0}@media (max-width:480px){.login-screen{padding:12px}.login-container{padding:24px}.login-header h1{font-size:24px}.demo-buttons{flex-direction:column}.demo-button{min-width:auto}}.register-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.register-container{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:500px;overflow-y:auto;padding:40px;width:100%}.register-header{margin-bottom:32px;text-align:center}.register-logo{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;display:inline-flex;height:80px;justify-content:center;margin-bottom:16px;width:80px}.register-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.register-header p{color:#6b7280;font-size:14px;margin:0}.progress-indicator{align-items:center;display:flex;gap:16px;justify-content:center;margin-bottom:32px}.progress-step{flex-direction:column;gap:8px}.progress-step,.step-number{align-items:center;display:flex}.step-number{background:#e5e7eb;border-radius:50%;color:#9ca3af;font-size:14px;font-weight:600;height:36px;justify-content:center;transition:all .2s;width:36px}.progress-step.active .step-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.progress-step span{color:#6b7280;font-size:12px;font-weight:500}.progress-step.active span{color:#374151}.progress-line{background:#e5e7eb;height:2px;margin-top:-18px;width:40px}.error-message{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;font-size:14px;gap:8px;padding:12px}.error-message,.register-form{margin-bottom:24px}.step-content{min-height:400px}.step-header{margin-bottom:24px;text-align:center}.step-header h2{color:#1f2937;font-size:20px;font-weight:600;margin:0 0 6px}.step-header p{color:#6b7280;font-size:13px;margin:0}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;margin-bottom:6px}.input-group{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;left:12px;position:absolute;z-index:1}.input-group input,.input-group select,.input-group textarea{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:14px;padding:12px 12px 12px 44px;transition:all .2s;width:100%}.input-group textarea{min-height:80px;padding-top:12px;resize:vertical}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.input-group input.error,.input-group select.error,.input-group textarea.error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.input-group input:disabled,.input-group select:disabled,.input-group textarea:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.role-display{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-size:14px;font-weight:500;padding:12px 12px 12px 44px;width:100%}.password-toggle{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;padding:4px;position:absolute;right:12px;transition:color .2s}.password-toggle:hover:not(:disabled){color:#6b7280}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.field-error{color:#dc2626}.field-error,.field-hint{display:block;font-size:12px;margin-top:4px}.field-hint{color:#6b7280;font-style:italic}.form-actions{display:flex;gap:12px;margin-top:32px}.prev-button{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px;transition:all .2s}.prev-button:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;color:#374151}.next-button,.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:2 1;font-size:14px;font-weight:600;padding:12px;transition:all .2s}.next-button:hover:not(:disabled),.submit-button:hover:not(:disabled){box-shadow:0 10px 25px -5px #667eea4d;transform:translateY(-1px)}.next-button:disabled,.prev-button:disabled,.submit-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.register-footer{border-top:1px solid #e5e7eb;padding-top:20px;text-align:center}.register-footer p{color:#6b7280;font-size:14px;margin:0}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:500;text-decoration:underline}.link-button:hover:not(:disabled){color:#5a67d8}.link-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:480px){.register-screen{padding:12px}.register-container{max-width:100%;padding:24px}.register-header h1{font-size:24px}.progress-indicator{gap:12px}.progress-line{width:30px}.step-content{min-height:350px}.form-actions{flex-direction:column}.next-button,.prev-button,.submit-button{flex:1 1}}.page-header{margin-bottom:32px}.page-header h1{align-items:center;color:#1a1a1a;display:flex;font-size:28px;font-weight:600;gap:12px;margin:0 0 8px}.page-header p{color:#666;margin:0}.page-icon{color:#2563eb}.alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:12px;margin-bottom:24px;padding:16px 20px}.alert-error{background-color:#fee;border:1px solid #fcc;color:#c00}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.section-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:24px}.section-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.section-header h3{align-items:center;color:#1a1a1a;display:flex;font-size:20px;font-weight:600;gap:12px;margin:0}.company-form{grid-gap:20px;display:grid;gap:20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#333;font-size:14px;font-weight:500}.form-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 14px;transition:all .2s}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-outline{background-color:#fff;border:1px solid #2563eb;color:#2563eb}.btn-outline:hover:not(:disabled){background-color:#eff6ff}.employees-table{overflow-x:auto}.employees-table table{border-collapse:collapse;width:100%}.employees-table th{background-color:#f9fafb;border-bottom:2px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;padding:12px;text-align:left}.employees-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;font-size:14px;padding:14px 12px}.employee-name{font-weight:500}.role-badge,.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.role-badge.role-admin{background-color:#dbeafe;color:#1e40af}.role-badge.role-manager{background-color:#e0e7ff;color:#4338ca}.status-badge.status-active{background-color:#d1fae5;color:#065f46}.status-badge.status-inactive{background-color:#fee2e2;color:#991b1b}
/*# sourceMappingURL=main.3b68123f.css.map*/