*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5}body{background:#f9fafb;max-width:100vw;min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font:inherit;color:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}.app-layout{min-height:100vh;display:flex}.sidebar{color:#9ca3af;z-index:40;background:#111827;flex-direction:column;width:240px;transition:transform .2s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:20px 20px 16px}.sidebar-brand h2{color:#fff;letter-spacing:-.01em;font-size:16px;font-weight:700}.sidebar-brand span{color:#6b7280;margin-top:2px;font-size:11px;display:block}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.sidebar-nav a,.sidebar-nav button{color:#9ca3af;text-align:left;border-radius:6px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.sidebar-nav a:hover,.sidebar-nav button:hover{color:#e5e7eb;background:#ffffff0f}.sidebar-nav a.active{color:#fff;background:#1a56db}.sidebar-nav a.active svg{color:#fff}.sidebar-nav svg{flex-shrink:0;width:18px;height:18px}.sidebar-user{border-top:1px solid #ffffff14;align-items:center;gap:10px;padding:16px;display:flex}.sidebar-user-avatar{color:#e5e7eb;background:#374151;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#e5e7eb;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.sidebar-user-role{color:#6b7280;text-transform:capitalize;font-size:11px}.main-content{flex:1;max-width:100vw;min-height:100vh;margin-left:240px;overflow-x:hidden}.page-container{box-sizing:border-box;width:100%;max-width:1200px;padding:28px 32px}.mobile-topbar{color:#fff;z-index:50;background:#111827;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0}.mobile-topbar h2{font-size:15px;font-weight:600}.mobile-topbar button{color:#9ca3af;padding:8px}.mobile-topbar button:hover{color:#fff}.sidebar-overlay{z-index:35;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.open{display:block}.login-page{background:#f3f4f6;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:28px}.login-header .logo{margin-bottom:12px;font-size:40px}.login-header h1{color:#111827;margin-bottom:4px;font-size:20px;font-weight:600}.login-header p{color:#6b7280;font-size:14px}.login-form{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:28px;box-shadow:0 1px 3px #0000000f}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.form-group{margin-bottom:16px}.form-label{color:#374151;margin-bottom:5px;font-size:13px;font-weight:500;display:block}.form-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:9px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:#1a56db;outline:none;box-shadow:0 0 0 3px #1a56db1a}.form-input::placeholder{color:#9ca3af}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:36px}textarea.form-input{resize:vertical;min-height:80px}.btn{white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-size:13.5px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:#1a56db}.btn-primary:hover{background:#1544b0}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-secondary:hover{background:#f9fafb}.btn-danger{color:#fff;background:#dc2626}.btn-danger:hover{background:#b91c1c}.btn-ghost{color:#6b7280;padding:6px 10px}.btn-ghost:hover{color:#111827;background:#f3f4f6}.btn-sm{padding:6px 12px;font-size:12px}.btn-full{width:100%}.btn-icon{border-radius:6px;padding:6px}.btn-icon:hover{background:#f3f4f6}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px}.card-header{border-bottom:1px solid #f3f4f6;padding:16px 20px}.card-body{padding:20px}.card-footer{background:#fafafa;border-top:1px solid #f3f4f6;border-radius:0 0 8px 8px;padding:12px 20px}.page-header{margin-bottom:24px}.page-header h1{color:#111827;font-size:20px;font-weight:600}.page-header p{color:#6b7280;margin-top:2px;font-size:13.5px}.page-header-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.grid-6{grid-template-columns:repeat(6,1fr);gap:12px;display:grid}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px 20px}.stat-card .stat-value{color:#111827;margin-bottom:2px;font-size:22px;font-weight:700}.stat-card .stat-label{color:#6b7280;font-size:12.5px}.stat-card .stat-sub{color:#9ca3af;margin-top:4px;font-size:11px}.stat-card .stat-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:10px;font-size:18px;display:flex}.stat-icon-blue{color:#1a56db;background:#eff6ff}.stat-icon-green{color:#059669;background:#ecfdf5}.stat-icon-purple{color:#7c3aed;background:#f5f3ff}.stat-icon-orange{color:#ea580c;background:#fff7ed}.stat-icon-red{color:#dc2626;background:#fef2f2}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb;padding:10px 16px;font-size:12px;font-weight:600}td{color:#374151;border-bottom:1px solid #f3f4f6;padding:12px 16px;font-size:13.5px}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-blue{color:#1a56db;background:#eff6ff}.badge-green{color:#059669;background:#ecfdf5}.badge-red{color:#dc2626;background:#fef2f2}.badge-yellow{color:#d97706;background:#fffbeb}.badge-purple{color:#7c3aed;background:#f5f3ff}.badge-gray{color:#6b7280;background:#f3f4f6}.badge-orange{color:#ea580c;background:#fff7ed}.tabs{-webkit-overflow-scrolling:touch;background:#f3f4f6;border-radius:8px;gap:2px;margin-bottom:20px;padding:3px;display:flex;overflow-x:auto}.tab{color:#6b7280;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:7px 16px;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:#374151}.tab.active{color:#111827;background:#fff;box-shadow:0 1px 2px #0000000f}.progress-bar{background:#f3f4f6;border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{border-radius:3px;height:100%;transition:width .3s}.progress-bar-fill.green{background:#10b981}.progress-bar-fill.yellow{background:#f59e0b}.progress-bar-fill.red{background:#ef4444}.progress-bar-fill.blue{background:#3b82f6}.list-item{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex}.list-item:last-child{border-bottom:none}.list-item:hover{background:#fafafa}.empty-state{text-align:center;color:#9ca3af;padding:48px 20px;font-size:14px}.qr-sign-page{background:#fff;min-height:100vh}.qr-sign-header{color:#fff;text-align:center;background:#111827;padding:32px 24px}.qr-sign-header h1{font-size:24px;font-weight:700}.qr-sign-header p{color:#9ca3af;margin-top:4px;font-size:14px}.qr-sign-grid{grid-template-columns:repeat(3,1fr);gap:20px;max-width:800px;margin:0 auto;padding:32px 24px;display:grid}.qr-sign-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px 16px}.qr-sign-card h3{color:#111827;margin-top:14px;font-size:14px;font-weight:600}.qr-sign-card p{color:#6b7280;margin-top:2px;font-size:12px}.qr-sign-footer{text-align:center;color:#9ca3af;border-top:1px solid #f3f4f6;padding:24px;font-size:12px}.entry-layout{background:#fff;min-height:100vh}.entry-topbar{z-index:20;background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.entry-topbar a{color:#6b7280;align-items:center;display:flex}.entry-topbar a:hover{color:#111827}.entry-topbar h1{font-size:16px;font-weight:600}.entry-content{max-width:480px;margin:0 auto;padding:20px 16px}.toggle-group{gap:6px;display:flex}.toggle-btn{text-align:center;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;flex:1;padding:8px 12px;font-size:13px;font-weight:500;transition:all .15s}.toggle-btn.active{color:#fff;background:#1a56db;border-color:#1a56db}.modal-backdrop{z-index:50;background:#0000004d;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 30px #0000001f}.modal-header{padding:20px 20px 0}.modal-header h2{font-size:16px;font-weight:600}.modal-body{padding:16px 20px}.modal-footer{justify-content:flex-end;gap:8px;padding:12px 20px 20px;display:flex}.chart-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.chart-container h3{color:#111827;margin-bottom:16px;font-size:14px;font-weight:600}.quick-entry-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.quick-entry-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:all .15s;display:block}.quick-entry-card:hover{border-color:#1a56db;box-shadow:0 2px 8px #1a56db14}.quick-entry-card .icon{margin-bottom:6px;font-size:24px}.quick-entry-card h3{color:#111827;font-size:13px;font-weight:600}.quick-entry-card p{color:#9ca3af;font-size:11px}.section{margin-bottom:28px}.section:last-child{margin-bottom:0}.section-title{color:#374151;margin-bottom:12px;font-size:14px;font-weight:600}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.green{background:#10b981}.status-dot.red{background:#ef4444}.status-dot.yellow{background:#f59e0b}.avatar{color:#6b7280;background:#f3f4f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.toast-container{z-index:100;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-lg{font-size:18px}.text-xl{font-size:20px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray{color:#6b7280}.text-light-gray{color:#9ca3af}.text-dark{color:#111827}.text-blue{color:#1a56db}.text-red{color:#dc2626}.text-green{color:#059669}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.p-3{padding:12px}.p-4{padding:16px}.p-5{padding:20px}.px-3{padding-left:12px;padding-right:12px}.py-2{padding-top:8px;padding-bottom:8px}.w-full{width:100%}.hidden{display:none}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.space-y-3>*+*{margin-top:12px}.space-y-4>*+*{margin-top:16px}.space-y-6>*+*{margin-top:24px}.divide>*+*{border-top:1px solid #f3f4f6}.opacity-40{opacity:.4}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}@media (max-width:1024px){.grid-4,.grid-3,.qr-sign-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding-top:56px}.mobile-topbar{display:flex}.page-container{box-sizing:border-box;width:100%;padding:12px 10px;overflow-x:hidden}.grid-2,.grid-3,.grid-4,.grid-6{grid-template-columns:1fr}.quick-entry-grid{grid-template-columns:repeat(2,1fr)}.qr-sign-grid{grid-template-columns:1fr;max-width:320px}.page-header-row{flex-direction:column;align-items:flex-start;width:100%}.stat-card .stat-value{font-size:18px}.inv-table-desktop{display:none!important}.inv-cards-mobile{display:block!important}.inv-card{padding:8px 6px!important}}.inv-cards-mobile{display:none}.inv-table-desktop{display:block}.inv-card{padding:10px 14px}.inv-count-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.inv-count-bar-row{flex:auto;align-items:flex-end;gap:12px;min-width:0;display:flex}.inv-vendor-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;align-items:center;gap:6px;margin-bottom:8px;padding-bottom:4px;display:flex;overflow-x:auto}.inv-section-block{margin-bottom:16px}.inv-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:#f1f3f5;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.inv-section-title{margin:0;font-size:15px;font-weight:700}@media (max-width:768px){.inv-count-bar{flex-direction:column;align-items:stretch}.inv-count-bar-row{flex-wrap:wrap}.inv-vendor-tabs{gap:4px}.inv-vendor-tabs .tab{white-space:nowrap;padding:4px 8px;font-size:11px}.inv-section-header{padding:10px!important}.inv-section-title{font-size:13px!important}.tab{padding:6px 10px;font-size:12px}.tabs{gap:1px}}
