.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:420px;padding:48px 40px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#1f2937}.login-header p{margin:0;color:#6b7280;font-size:16px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.login-button{margin-top:8px;padding:14px;font-size:16px}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb;text-align:center}.demo-info{margin:0;color:#6b7280;font-size:13px}.divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#9ca3af;font-size:14px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.google-login-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s}.google-login-button:hover:not(:disabled){background:#f9fafb;box-shadow:0 1px 4px #0000001f}.google-login-button:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;width:100%;animation:modalIn .15s ease-out}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:780px}.modal-xl{max-width:1020px}@keyframes modalIn{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #e5e7eb}.modal-title{margin:0;font-size:18px;font-weight:600;color:#1f2937}.modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:#9ca3af;padding:4px 8px;border-radius:4px;line-height:1;transition:color .15s}.modal-close:hover{color:#374151;background:#f3f4f6}.modal-body{padding:24px;overflow-y:auto;flex:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.button-danger{background-color:#dc2626;color:#fff;padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.button-danger:hover{background-color:#b91c1c}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:9999px;font-size:12px;font-weight:500}.badge-green{background:#d1fae5;color:#065f46}.badge-gray{background:#f3f4f6;color:#4b5563}.badge-red{background:#fee2e2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-orange{background:#ffedd5;color:#9a3412}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;z-index:9999;animation:toastIn .2s ease-out}.toast-success{background:#059669;color:#fff}.toast-error{background:#dc2626;color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.btn-icon{background:none;border:none;cursor:pointer;padding:5px;border-radius:4px;line-height:0;transition:background-color .15s;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background-color:#f3f4f6}.btn-icon-edit{color:#2563eb}.btn-icon-delete,.btn-icon-danger{color:#dc2626}.action-buttons{display:flex;align-items:center;gap:2px;white-space:nowrap;flex-wrap:nowrap}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}textarea.input{resize:vertical;min-height:80px}.mrp-page{display:flex;flex-direction:column;height:100%;background:#f9fafb;position:relative}.mrp-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:12px 24px;display:flex;align-items:center;gap:20px;flex-shrink:0}.mrp-back-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.mrp-back-btn:hover{background:#e5e7eb;border-color:#d1d5db}.mrp-breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:#9ca3af;flex-wrap:wrap}.mrp-sep{color:#d1d5db}.mrp-bc-current{color:#374151;font-weight:500}.mrp-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:20px;min-height:0}.mrp-item-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px 20px;display:flex;align-items:flex-start;gap:14px;flex-shrink:0}.mrp-item-icon{width:42px;height:42px;border-radius:10px;background:#fff7ed;color:#ea580c;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mrp-item-info{flex:1}.mrp-item-name{font-size:16px;font-weight:700;color:#111827;margin-bottom:4px}.mrp-item-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:#6b7280}.mrp-item-desc{display:flex;align-items:center;gap:4px;color:#9ca3af}.mrp-item-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#eff6ff;color:#1d4ed8;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.mrp-dnd-layout{display:flex;gap:16px;flex:1;min-height:0;align-items:flex-start}.mrp-palette{width:260px;min-width:220px;max-width:280px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 240px);position:sticky;top:0}.mrp-palette-header{padding:12px 14px 10px;border-bottom:1px solid #f3f4f6;display:flex;align-items:baseline;justify-content:space-between;flex-shrink:0}.mrp-palette-title{font-size:13px;font-weight:600;color:#374151}.mrp-palette-hint{font-size:11px;color:#9ca3af}.mrp-palette-search-wrap{position:relative;padding:10px 12px 6px;flex-shrink:0}.mrp-palette-search-icon{position:absolute;left:20px;top:50%;transform:translateY(-20%);color:#9ca3af;pointer-events:none}.mrp-palette-search{width:100%;height:32px;padding:0 8px 0 28px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;background:#f9fafb;box-sizing:border-box;outline:none;transition:border-color .15s,background .15s}.mrp-palette-search:focus{border-color:#93c5fd;background:#fff}.mrp-category-selects{display:flex;flex-direction:column;gap:5px;padding:4px 12px 8px;flex-shrink:0}.mrp-cat-select{width:100%;height:28px;padding:0 6px;border:1px solid #e5e7eb;border-radius:6px;font-size:12px;color:#374151;background:#f9fafb;cursor:pointer;outline:none;transition:border-color .15s,background .15s}.mrp-cat-select:focus{border-color:#93c5fd;background:#fff}.mrp-palette-tabs{display:flex;gap:3px;margin-bottom:6px;padding:0 12px}.mrp-palette-tab{flex:1;min-width:0;padding:4px 2px;font-size:10px;font-weight:500;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb;color:#6b7280;cursor:pointer;transition:all .15s;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}.mrp-palette-tab:hover{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.mrp-palette-tab.active{background:#2563eb;border-color:#2563eb;color:#fff}.mrp-category-chips{display:flex;flex-wrap:wrap;gap:5px;padding:4px 12px 8px;flex-shrink:0}.mrp-category-chip{padding:3px 10px;border-radius:20px;border:1px solid #e5e7eb;background:#f9fafb;font-size:11px;font-weight:500;color:#6b7280;cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.mrp-category-chip:hover{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.mrp-category-chip.active{background:#2563eb;border-color:#2563eb;color:#fff}.mrp-category-chip.chip-semi{border-color:#fde68a;color:#92400e;background:#fffbeb}.mrp-category-chip.chip-semi:hover{background:#fef3c7;border-color:#fbbf24}.mrp-category-chip.chip-semi.active{background:#d97706;border-color:#d97706;color:#fff}.mrp-ingredient-list{flex:1;overflow-y:auto;padding:4px 10px 10px;display:flex;flex-direction:column;gap:5px}.mrp-ingredient-card{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border:1px solid #e5e7eb;border-radius:7px;background:#fafafa;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .2s cubic-bezier(.34,1.56,.64,1),background .12s,border-color .12s,box-shadow .12s,opacity .2s}.mrp-ingredient-card:hover{background:#eff6ff;border-color:#bfdbfe;box-shadow:0 1px 4px #2563eb14;transform:translateY(-1px)}.mrp-ingredient-card:active{cursor:grabbing}.mrp-ingredient-card.dragging{opacity:.5;transform:rotate(5deg) scale(.95);box-shadow:0 4px 12px #00000026}.mrp-ingredient-card.disabled{opacity:.38;cursor:not-allowed;background:#f3f4f6;border-color:#e5e7eb}.mrp-ingredient-card.disabled:hover{transform:none;box-shadow:none;background:#f3f4f6;border-color:#e5e7eb}.mrp-palette-loading{font-size:13px;color:#6b7280;padding:6px 4px 2px;text-align:center}.mrp-palette-loading-more{font-size:12px;color:#9ca3af;padding:3px 4px 0;text-align:center}.mrp-card-name{font-size:13px;font-weight:500;color:#111827;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:6px}.mrp-card-meta{display:flex;align-items:center;gap:5px;flex-shrink:0}.mrp-card-badge{display:inline-block;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:600}.mrp-card-unit{font-size:11px;color:#6b7280}.mrp-palette-empty{text-align:center;color:#9ca3af;font-size:12px;padding:24px 8px}.mrp-palette-pager{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-top:1px solid #f3f4f6;flex-shrink:0;min-height:44px}.mrp-pager-size-select{height:26px;padding:0 4px;border:1px solid #e5e7eb;border-radius:6px;font-size:11px;color:#6b7280;background:#f9fafb;cursor:pointer;outline:none;transition:border-color .12s}.mrp-pager-size-select:focus{border-color:#93c5fd}.mrp-pager-btn{width:28px;height:28px;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb;color:#374151;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s}.mrp-pager-btn:hover:not(:disabled){background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.mrp-pager-btn:disabled{opacity:.35;cursor:not-allowed}.mrp-pager-info{font-size:12px;font-weight:500;color:#6b7280;text-align:center}.mrp-pager-total{font-size:11px;color:#9ca3af;margin-left:4px}.mrp-bom-panel{flex:1;min-width:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;display:flex;flex-direction:column}.mrp-bom-item-header{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;background:linear-gradient(135deg,#eff6ff,#f0fdf4);border-bottom:2px solid #2563eb;flex-shrink:0}.mrp-bom-item-icon{width:38px;height:38px;border-radius:10px;background:#fff;color:#2563eb;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 4px #2563eb26}.mrp-bom-item-info{flex:1;min-width:0}.mrp-bom-item-name{font-size:20px;font-weight:700;color:#111827;margin-bottom:4px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mrp-bom-item-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:#4b5563}.mrp-bom-item-desc{display:flex;align-items:center;gap:4px;color:#6b7280}.mrp-bom-item-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#2563eb;color:#fff;border-radius:8px;font-size:12px;font-weight:600;white-space:nowrap;flex-shrink:0}.mrp-status-filter{display:flex;gap:5px;padding:6px 12px 4px;flex-shrink:0;flex-wrap:wrap}.mrp-status-chip{padding:3px 9px;border-radius:12px;border:1px solid #e5e7eb;background:#f9fafb;font-size:11px;font-weight:500;color:#6b7280;cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.mrp-status-chip:hover{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.mrp-status-chip.active{background:#2563eb;border-color:#2563eb;color:#fff}.mrp-section-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.mrp-section-header h3{margin:0;font-size:14px;font-weight:600;color:#374151}.mrp-drop-hint{font-size:12px;color:#9ca3af}.mrp-drop-zone{flex:1;display:flex;flex-direction:column;transition:background .15s,outline .15s;outline:2px dashed transparent;outline-offset:-4px}.mrp-drop-zone.dragging{outline-color:#bfdbfe;background:#f0f7ff}.mrp-drop-zone.dragging.over,.mrp-drop-zone.over{background:#dbeafe;outline-color:#3b82f6}.mrp-table{width:100%;margin:0}.mrp-section .table thead tr:first-child th:first-child,.mrp-bom-panel .table thead tr:first-child th:first-child{border-radius:0}.mrp-section .table thead tr:first-child th:last-child,.mrp-bom-panel .table thead tr:first-child th:last-child{border-radius:0}.mrp-num{color:#9ca3af;font-size:12px;text-align:center}.mrp-name{font-weight:500;color:#111827}.mrp-unit{color:#6b7280;font-size:13px}.mrp-empty-row{text-align:center;color:#9ca3af;font-size:13px;padding:32px}.mrp-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.badge-material{background:#dcfce7;color:#15803d}.badge-semi{background:#fef3c7;color:#92400e}.badge-finished{background:#e0f2fe;color:#0369a1}.mrp-del-btn{background:none;border:none;cursor:pointer;color:#ef4444;padding:4px;border-radius:4px;display:flex;align-items:center;transition:background .15s}.mrp-del-btn:hover{background:#fee2e2}.mrp-del-btn:disabled{opacity:.4;cursor:not-allowed}.mrp-edit-btn{background:#3b82f6;border:1px solid #2563eb;cursor:pointer;color:#fff;padding:4px;border-radius:4px;display:flex;align-items:center;transition:background .15s}.mrp-edit-btn:hover:not(:disabled){background:#2563eb}.mrp-edit-btn:disabled{opacity:.5;cursor:not-allowed}.mrp-pending-row{background:#f0f9ff}.mrp-pending-row td{padding:8px 12px!important;border-top:2px dashed #7dd3fc}.mrp-qty-input,.mrp-unit-input{height:32px;padding:0 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;background:#fff;width:100%;box-sizing:border-box}.mrp-ok-btn{min-width:28px;height:28px;padding:0 12px;background:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;flex-shrink:0;font-size:12px;font-weight:500;white-space:nowrap;transition:background .15s}.mrp-ok-btn:hover:not(:disabled){background:#1d4ed8}.mrp-ok-btn:disabled{background:#93c5fd;cursor:not-allowed}.mrp-cancel-btn{width:28px;height:28px;background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.mrp-cancel-btn:hover{background:#fee2e2;color:#ef4444}.mrp-drop-zone-empty-cell{padding:0!important}.mrp-drop-zone-cta{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;border:2px dashed #bfdbfe;border-radius:8px;margin:12px;background:#f8faff;transition:border-color .15s,background .15s}.mrp-drop-zone.over .mrp-drop-zone-cta{border-color:#3b82f6;background:#eff6ff}.mrp-drop-zone-icon{font-size:28px;color:#93c5fd;line-height:1}.mrp-drop-zone-label{font-size:14px;font-weight:500;color:#60a5fa}.mrp-drop-indicator{padding:12px 20px;text-align:center;font-size:12px;color:#d1d5db;border-top:1px dashed #e5e7eb;-webkit-user-select:none;user-select:none;transition:color .15s,border-color .15s,background .15s}.mrp-drop-zone.dragging .mrp-drop-indicator{color:#60a5fa;border-top-color:#bfdbfe;background:#eff6ff;font-weight:500}.mrp-state-msg{padding:32px;text-align:center;color:#9ca3af;font-size:13px}.mrp-toast{position:fixed;top:20px;right:24px;padding:10px 18px;border-radius:8px;font-size:13px;font-weight:500;z-index:9999;box-shadow:0 4px 12px #00000026}.mrp-toast-ok{background:#d1fae5;color:#065f46}.mrp-toast-err{background:#fee2e2;color:#991b1b}.mrp-unit-toggle{display:flex;gap:2px;background:#f3f4f6;border-radius:6px;padding:2px;border:1px solid #e5e7eb}.mrp-unit-btn{padding:4px 10px;font-size:12px;font-weight:500;color:#6b7280;background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .15s;white-space:nowrap;min-width:36px}.mrp-unit-btn:hover{color:#374151;background:#e5e7eb}.mrp-unit-btn.active{color:#1e40af;background:#fff;font-weight:600;box-shadow:0 1px 2px #0000000d}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:250px;background-color:#1f2937;color:#fff;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid #374151;display:flex;align-items:center;gap:10px}.sidebar-home-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:#9ca3af;flex-shrink:0;transition:background .2s,color .2s;text-decoration:none}.sidebar-home-btn:hover,.sidebar-home-btn.active{background:#ffffff1f;color:#fff}.sidebar-title{margin:0;font-size:20px;font-weight:700;color:#fff}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.sidebar-footer{border-top:1px solid #374151;padding:16px;background-color:#111827}.sidebar-user{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin-bottom:8px;border-radius:6px;background-color:#ffffff0d}.sidebar-user-info{display:flex;flex-direction:column;gap:4px}.sidebar-user-name{color:#e5e7eb;font-size:14px;font-weight:500}.sidebar-viewer-badge{display:inline-block;padding:1px 8px;background:#fbbf2426;border:1px solid rgba(251,191,36,.4);border-radius:4px;color:#fbbf24;font-size:11px;font-weight:600;letter-spacing:.03em}.sidebar-logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#fca5a5;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.sidebar-logout-btn:hover{background:#ef444433;border-color:#ef444480;color:#fecaca}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#d1d5db;text-decoration:none;transition:all .2s}.nav-item:hover{background-color:#374151;color:#fff}.nav-item.active{background-color:#2563eb;color:#fff}.nav-item>svg{flex-shrink:0}.nav-icon{width:28px;height:28px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.nav-item.active .nav-icon{background:#fff3!important;color:#fff!important}.main-content{flex:1;display:flex;flex-direction:column;background-color:#f9fafb;overflow-y:auto}.header{height:64px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.header-left h2{margin:0;font-size:18px;font-weight:600;color:#1f2937}.header-right{display:flex;align-items:center;gap:16px}.user-name{color:#6b7280;font-size:14px}.content{flex:1;overflow-y:auto}.nav-section-label{display:flex;align-items:center;gap:8px;padding:14px 16px 4px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6b7280;-webkit-user-select:none;user-select:none}.nav-section-label:before,.nav-section-label:after{content:"";flex:1;height:1px;background:#374151}.nav-accordion-trigger{width:100%;background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.accordion-chevron{transition:transform .25s ease;opacity:.6;flex-shrink:0}.accordion-chevron.open{transform:rotate(-180deg);opacity:1}.accordion-body{overflow:hidden;max-height:0;transition:max-height .3s ease}.accordion-body.open{max-height:400px}.nav-sub-item{display:flex;align-items:center;gap:12px;padding:9px 20px 9px 36px;color:#9ca3af;text-decoration:none;font-size:13px;transition:all .2s;border-left:2px solid transparent}.nav-sub-item:hover{color:#e5e7eb;background-color:#2d3748;border-left-color:#ea580c}.nav-sub-item.active{color:#fff;background-color:#ea580c26;border-left-color:#ea580c}.nav-sub-item.active .nav-icon{background:#ffffff26!important;color:#fff!important}.notif-bell-wrapper{position:relative;flex-shrink:0}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:#ffffff1a;color:#ffffffd9;cursor:pointer;transition:background .15s}.notif-bell-btn:hover{background:#fff3}.notif-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center}.notif-dropdown{position:absolute;bottom:calc(100% + 8px);right:0;width:320px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;overflow:hidden}.notif-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #f3f4f6}.notif-dropdown-title{font-size:14px;font-weight:600;color:#111827}.notif-read-all-btn{font-size:12px;color:#6366f1;background:none;border:none;cursor:pointer;padding:0}.notif-read-all-btn:hover{text-decoration:underline}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{padding:24px;text-align:center;font-size:13px;color:#9ca3af}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid #f9fafb;cursor:pointer;transition:background .1s}.notif-item:hover{background:#f9fafb}.notif-item--read{opacity:.6}.notif-unread-dot{flex-shrink:0;width:8px;height:8px;margin-top:5px;border-radius:50%;background:#6366f1}.notif-item-content{flex:1;min-width:0}.notif-item-title{font-size:13px;font-weight:600;color:#111827;margin-bottom:2px}.notif-item-body{font-size:12px;color:#6b7280;line-height:1.4;word-break:break-all}.notif-item-time{font-size:11px;color:#9ca3af;margin-top:4px}.master-layout{display:flex;flex-direction:column;height:100%}.master-tab-bar{background:#fff;border-bottom:1px solid #e5e7eb}.master-tab-bar-header{padding:20px 24px 0}.master-tab-bar-title{font-size:24px;font-weight:600;color:#1a1a1a;letter-spacing:normal;text-transform:none}.master-tabs{display:flex;gap:6px;padding:12px 20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#f9fafb;border-top:1px solid #e5e7eb}.master-tabs::-webkit-scrollbar{display:none}.master-tab{display:flex;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:500;color:#6b7280;text-decoration:none;white-space:nowrap;border-radius:6px;border:1.5px solid #e5e7eb;background:#fff;transition:color .15s,border-color .15s,background .15s,box-shadow .15s;cursor:pointer}.master-tab svg{transition:opacity .15s}.master-tab:hover{color:#374151;border-color:#9ca3af;background:#f3f4f6;box-shadow:0 1px 3px #0000000f}.master-tab-active{color:#fff;border-color:#2563eb;background:#2563eb;box-shadow:0 2px 6px #2563eb59}.master-tab-active svg{color:#fff!important}.master-tab-divider{display:inline-block;width:1px;background:#e5e7eb;margin:4px 2px;align-self:stretch}.mobile-layout{display:flex;flex-direction:column;height:100dvh;height:100vh;background:#f9fafb;overflow:hidden}.mobile-header{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 4px;background:#1f2937;color:#fff;flex-shrink:0;padding-top:env(safe-area-inset-top,0);min-height:calc(52px + env(safe-area-inset-top,0px))}.mobile-header-back{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:transparent;color:#fff;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-header-back:active{background:#ffffff26}.mobile-header-title{font-size:16px;font-weight:700;color:#fff;margin:0;text-align:center;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px}.mobile-header-placeholder{width:44px;flex-shrink:0}.mobile-header-logout{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:transparent;color:#9ca3af;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0}.mobile-header-logout:active{background:#ffffff26;color:#fff}.mobile-main{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:4px}.mobile-bottom-nav{display:flex;align-items:stretch;height:60px;background:#1f2937;border-top:1px solid #374151;flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,0);min-height:calc(60px + env(safe-area-inset-bottom,0px))}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#9ca3af;text-decoration:none;font-size:10px;font-weight:500;border:none;background:transparent;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .15s,background .15s;padding:6px 2px;border-radius:0}.mobile-nav-item:active{background:#ffffff14}.mobile-nav-item.active{color:#60a5fa}.mobile-nav-item svg{flex-shrink:0}.mobile-nav-item span{line-height:1}.ms-page{padding:12px;position:relative;min-height:100%}.ms-loading,.ms-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:#9ca3af;gap:12px;text-align:center}.ms-empty p{margin:0;font-size:15px;font-weight:500;color:#6b7280}.ms-empty-sub{font-size:13px!important;color:#9ca3af!important;font-weight:400!important}.ms-list{display:flex;flex-direction:column;gap:10px;padding-bottom:80px}.ms-card{display:flex;align-items:center;justify-content:space-between;width:100%;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 3px #0000000f;transition:box-shadow .15s,transform .1s}.ms-card:active{transform:scale(.985);box-shadow:none}.ms-card-main{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.ms-card-date{font-size:17px;font-weight:700;color:#111827}.ms-card-store{font-size:13px;color:#6b7280}.ms-card-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.ms-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.ms-badge-initial{background:#fff7ed;color:#c2410c}.ms-card-notes{font-size:12px;color:#9ca3af;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ms-fab{position:fixed;right:20px;bottom:calc(70px + env(safe-area-inset-bottom,0px));width:56px;height:56px;border-radius:50%;background:#1d4ed8;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #1d4ed873;-webkit-tap-highlight-color:transparent;z-index:10;transition:transform .15s}.ms-fab:active{transform:scale(.92)}.ms-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:flex-end}.ms-sheet{width:100%;background:#fff;border-radius:20px 20px 0 0;padding:12px 20px 32px;max-height:85dvh;overflow-y:auto;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px))}.ms-sheet-handle{width:40px;height:4px;background:#d1d5db;border-radius:2px;margin:0 auto 16px}.ms-sheet-title{font-size:18px;font-weight:700;color:#111827;margin:0 0 20px}.ms-form-row{margin-bottom:16px}.ms-form-row-check{margin-bottom:20px}.ms-form-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.ms-required{color:#ef4444}.ms-input,.ms-select{width:100%;padding:12px 14px;border:1.5px solid #d1d5db;border-radius:10px;font-size:16px;color:#111827;background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none}.ms-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' 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-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:36px}.ms-input:focus,.ms-select:focus{outline:none;border-color:#1d4ed8}.ms-check-label{display:flex;align-items:center;gap:10px;font-size:15px;color:#374151;cursor:pointer}.ms-check-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.ms-sheet-actions{display:flex;gap:10px;margin-top:8px}.ms-btn{flex:1;padding:14px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.ms-btn:active{opacity:.7}.ms-btn-primary{background:#1d4ed8;color:#fff}.ms-btn-primary:disabled{opacity:.6;cursor:default}.ms-btn-ghost{background:#f3f4f6;color:#374151}.ms-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:20px;font-size:14px;font-weight:600;z-index:300;white-space:nowrap;box-shadow:0 4px 12px #00000026}.ms-toast-success{background:#111827;color:#fff}.ms-toast-error{background:#ef4444;color:#fff}.msd-page{padding:12px 12px 100px;min-height:100%}.msd-loading,.msd-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:16px;color:#6b7280}.msd-info-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:10px 14px;margin-bottom:10px;font-size:13px;color:#374151;font-weight:500}.msd-status{margin-left:auto;font-size:11px;font-weight:700;padding:3px 9px;border-radius:10px}.msd-status-gray{background:#f3f4f6;color:#6b7280}.msd-status-blue{background:#dbeafe;color:#1d4ed8}.msd-status-green{background:#d1fae5;color:#059669}.msd-banner{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:10px;line-height:1.5}.msd-banner-yellow{background:#fefce8;border:1px solid #fde68a;color:#92400e}.msd-banner-blue{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.msd-progress-bar-wrap{margin-bottom:10px}.msd-progress-label{display:flex;justify-content:space-between;font-size:13px;color:#6b7280;margin-bottom:6px}.msd-progress-label strong{color:#111827}.msd-progress-track{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.msd-progress-fill{height:100%;background:linear-gradient(90deg,#1d4ed8,#3b82f6);border-radius:3px;transition:width .3s ease}.msd-filter-bar{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;margin-bottom:10px;display:flex;flex-direction:column;gap:8px}.msd-filter-row2{display:flex;align-items:center;justify-content:space-between}.msd-type-tabs{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.msd-type-tabs::-webkit-scrollbar{display:none}.msd-type-tab{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.msd-type-tab-active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;font-weight:700}.msd-check-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:#374151;cursor:pointer}.msd-check-toggle input[type=checkbox]{width:16px;height:16px}.msd-search-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1.5px solid #e5e7eb;background:#fff;cursor:pointer;color:#6b7280;-webkit-tap-highlight-color:transparent}.msd-search-toggle-active{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.msd-search-bar{display:flex;align-items:center;gap:8px;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;padding:8px 12px}.msd-search-input{flex:1;border:none;background:transparent;font-size:15px;color:#111827;outline:none}.msd-search-input::placeholder{color:#9ca3af}.msd-search-clear{display:flex;align-items:center;justify-content:center;border:none;background:#e5e7eb;border-radius:50%;width:20px;height:20px;cursor:pointer;color:#6b7280;flex-shrink:0}.msd-cat-chips{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 0 4px}.msd-cat-chips::-webkit-scrollbar{display:none}.msd-cat-chip{flex-shrink:0;padding:5px 12px;border-radius:16px;border:1.5px solid #e5e7eb;background:#fff;font-size:12px;font-weight:500;color:#6b7280;cursor:pointer;-webkit-tap-highlight-color:transparent}.msd-cat-chip-active{background:#eff6ff;border-color:#1d4ed8;color:#1d4ed8}.msd-items-list{display:flex;flex-direction:column;gap:8px}.msd-item-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:12px 14px;transition:border-color .15s}.msd-item-entered{border-color:#a7f3d0;background:#f0fdf4}.msd-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}.msd-item-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.msd-item-type-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;flex-shrink:0}.msd-item-name{font-size:15px;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msd-saving-indicator{font-size:11px;color:#9ca3af;flex-shrink:0}.msd-saved-indicator{display:flex;align-items:center;gap:3px;font-size:11px;color:#059669;font-weight:600;flex-shrink:0}.msd-item-input-row{display:flex;align-items:center;gap:8px}.msd-qty-btn{width:44px;height:44px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;font-size:20px;color:#374151;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;transition:background .1s}.msd-qty-btn:active{background:#f3f4f6}.msd-qty-minus{border-color:#fca5a5;color:#dc2626}.msd-qty-minus:active{background:#fef2f2}.msd-qty-plus{border-color:#86efac;color:#16a34a}.msd-qty-plus:active{background:#f0fdf4}.msd-input-wrap{display:flex;align-items:center;gap:6px;flex:1;background:#f9fafb;border:1.5px solid #d1d5db;border-radius:10px;padding:4px 12px}.msd-qty-input{flex:1;border:none;background:transparent;font-size:22px;font-weight:700;color:#111827;outline:none;text-align:right;min-width:0;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.msd-qty-input::-webkit-outer-spin-button,.msd-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.msd-qty-input-sm{font-size:18px}.msd-unit{font-size:14px;font-weight:600;color:#6b7280;flex-shrink:0}.msd-draft-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.msd-add-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;overflow:hidden}.msd-add-card-added{border-color:#a7f3d0;background:#f0fdf4}.msd-add-card-header{display:flex;align-items:center;width:100%;padding:12px 14px;background:transparent;border:none;cursor:pointer;text-align:left;gap:8px;-webkit-tap-highlight-color:transparent}.msd-add-card-name{font-size:14px;font-weight:600;color:#111827;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msd-add-card-meta{font-size:11px;color:#9ca3af;flex-shrink:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.msd-add-card-added-badge{display:flex;align-items:center;gap:3px;color:#059669;font-weight:600;font-size:11px}.msd-add-card-body{padding:0 14px 12px;background:#f9fafb;border-top:1px solid #e5e7eb}.msd-add-input-row{display:flex;align-items:center;gap:8px;padding-top:10px}.msd-add-btn{padding:10px 18px;background:#1d4ed8;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0}.msd-add-btn:disabled{opacity:.6}.msd-summary-cards{display:flex;gap:10px;margin-bottom:14px}.msd-summary-item{flex:1;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px;text-align:center}.msd-summary-label{display:block;font-size:11px;color:#9ca3af;margin-bottom:4px}.msd-summary-value{font-size:24px;font-weight:700;color:#111827}.msd-ok{color:#10b981}.msd-section-title{font-size:13px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:12px 0 8px}.msd-diff-card{background:#fff;border-radius:10px;padding:12px 14px;margin-bottom:6px;border-left:4px solid}.msd-diff-minus{border-left-color:#ef4444;background:#fef2f2}.msd-diff-plus{border-left-color:#10b981;background:#f0fdf4}.msd-diff-name{font-size:14px;font-weight:600;color:#111827;margin-bottom:6px}.msd-diff-row{display:flex;gap:12px;font-size:12px;color:#6b7280;flex-wrap:wrap}.msd-diff-val{font-weight:700;color:#111827}.msd-completed-card{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;margin-bottom:4px}.msd-completed-name{flex:1;font-size:14px;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msd-completed-stock{font-size:14px;font-weight:700;color:#111827;flex-shrink:0}.msd-footer{position:fixed;bottom:0;left:0;right:0;display:flex;gap:10px;padding:12px 16px;background:#fff;border-top:1px solid #e5e7eb;z-index:10;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}.msd-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:13px 16px;border-radius:10px;font-size:14px;font-weight:700;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.msd-btn:active{opacity:.7}.msd-btn-primary{flex:2;background:#1d4ed8;color:#fff}.msd-btn-primary:disabled{opacity:.5;cursor:default}.msd-btn-outline{flex:1;background:#fff;color:#374151;border:1.5px solid #d1d5db}.msd-btn-outline:disabled{opacity:.6}.msd-btn-danger{flex:1;background:#dc2626;color:#fff}.msd-btn-danger:disabled{opacity:.6}.msd-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.msd-modal{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:340px}.msd-modal-title{font-size:17px;font-weight:700;color:#111827;margin:0 0 12px}.msd-modal-body{font-size:14px;color:#6b7280;margin:0 0 20px;line-height:1.6}.msd-modal-actions{display:flex;gap:10px}.msd-empty-text{text-align:center;color:#9ca3af;font-size:14px;padding:32px 16px}.msd-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:20px;font-size:14px;font-weight:600;z-index:300;white-space:nowrap;box-shadow:0 4px 12px #00000026;pointer-events:none}.msd-toast-success{background:#111827;color:#fff}.msd-toast-error{background:#ef4444;color:#fff}.mwp-container{display:flex;flex-direction:column;height:100%;background:#f3f4f6;overflow:hidden}.mwp-topbar{background:#fff;border-bottom:1px solid #e5e7eb;padding:10px 16px;flex-shrink:0}.mwp-topbar-row{display:flex;gap:10px;align-items:flex-end}.mwp-topbar-field{display:flex;flex-direction:column;gap:4px;flex:1}.mwp-topbar-date{flex:0 0 auto;width:145px}.mwp-topbar-label{font-size:11px;color:#6b7280;font-weight:500}.mwp-select-wrap{position:relative;display:flex;align-items:center}.mwp-select{width:100%;padding:8px 32px 8px 10px;border:1px solid #d1d5db;border-radius:8px;background:#f9fafb;font-size:14px;color:#111827;-moz-appearance:none;appearance:none;-webkit-appearance:none}.mwp-select:focus{outline:2px solid #3b82f6;outline-offset:-2px}.mwp-select-icon{position:absolute;right:8px;color:#6b7280;pointer-events:none}.mwp-date-input{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:8px;background:#f9fafb;font-size:13px;color:#111827}.mwp-date-input:focus{outline:2px solid #3b82f6;outline-offset:-2px}.mwp-scroll-area{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.mwp-section{background:#fff;margin-bottom:8px;padding:10px 16px 12px}.mwp-section-head{display:flex;align-items:center;gap:5px;font-size:11px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px}.mwp-recent-scroll{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.mwp-recent-scroll::-webkit-scrollbar{display:none}.mwp-recent-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;white-space:nowrap;flex-shrink:0;cursor:pointer;transition:background .15s}.mwp-recent-chip:active{background:#dbeafe}.mwp-recent-type{font-size:10px;color:#3b82f6;font-weight:600}.mwp-recent-name{font-size:13px;color:#1e3a8a;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis}.mwp-type-tabs{display:flex;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.mwp-type-tab{flex:1;padding:12px 8px;font-size:14px;color:#6b7280;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;transition:all .15s}.mwp-type-tab--active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.mwp-cat-scroll{display:flex;gap:6px;padding:10px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;background:#fff;flex-shrink:0}.mwp-cat-scroll::-webkit-scrollbar{display:none}.mwp-cat-chip{padding:5px 12px;border-radius:16px;border:1px solid #d1d5db;background:#f9fafb;font-size:12px;color:#374151;white-space:nowrap;cursor:pointer;transition:all .15s;flex-shrink:0}.mwp-cat-chip--active{background:#2563eb;border-color:#2563eb;color:#fff}.mwp-search-bar{background:#fff;padding:8px 16px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.mwp-search-open-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#9ca3af;cursor:pointer;text-align:left}.mwp-search-input-wrap{display:flex;align-items:center;gap:8px;background:#f3f4f6;border:1px solid #3b82f6;border-radius:8px;padding:0 10px}.mwp-search-icon{color:#6b7280;flex-shrink:0}.mwp-search-input{flex:1;padding:9px 0;background:none;border:none;font-size:14px;color:#111827;outline:none}.mwp-search-clear{color:#6b7280;background:none;border:none;padding:4px;cursor:pointer;display:flex}.mwp-search-toggle{font-size:12px;color:#6b7280;background:none;border:none;padding:4px 0 4px 6px;cursor:pointer;white-space:nowrap}.mwp-item-list{background:#fff}.mwp-item-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:#fff;border:none;border-bottom:1px solid #f3f4f6;cursor:pointer;text-align:left;transition:background .1s;min-height:52px}.mwp-item-row:active{background:#f0f9ff}.mwp-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.mwp-item-name{font-size:15px;color:#111827;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mwp-item-unit{font-size:12px;color:#9ca3af}.mwp-item-arrow{font-size:18px;color:#d1d5db;margin-left:8px;flex-shrink:0}.mwp-empty{padding:40px 16px;text-align:center;color:#9ca3af;font-size:14px}.mwp-list-bottom-pad{height:80px}.mwp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;opacity:0;pointer-events:none;transition:opacity .25s;z-index:900}.mwp-overlay--visible{opacity:1;pointer-events:auto}.mwp-sheet{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 24px #00000026;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);z-index:901;max-height:90dvh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,16px)}.mwp-sheet--open{transform:translateY(0)}.mwp-sheet-handle-bar{display:flex;justify-content:center;padding:10px 0 4px;flex-shrink:0}.mwp-sheet-handle{width:36px;height:4px;background:#d1d5db;border-radius:2px}.mwp-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 12px;border-bottom:1px solid #f3f4f6;flex-shrink:0}.mwp-sheet-title-group{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.mwp-sheet-type-badge{padding:2px 8px;border-radius:12px;background:#eff6ff;color:#2563eb;font-size:11px;font-weight:600;flex-shrink:0}.mwp-sheet-item-name{font-size:16px;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mwp-sheet-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f3f4f6;border:none;cursor:pointer;color:#6b7280;flex-shrink:0}.mwp-sheet-body{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;display:flex;flex-direction:column;gap:16px}.mwp-field{display:flex;flex-direction:column;gap:8px}.mwp-label{font-size:13px;font-weight:600;color:#374151}.mwp-qty-row{display:flex;align-items:center;gap:10px}.mwp-qty-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f3f4f6;border:1px solid #e5e7eb;font-size:20px;color:#374151;cursor:pointer;flex-shrink:0;line-height:1;transition:background .1s}.mwp-qty-btn:active{background:#e5e7eb}.mwp-qty-input{flex:1;padding:10px 12px;text-align:center;font-size:28px;font-weight:700;color:#111827;border:2px solid #e5e7eb;border-radius:10px;background:#f9fafb;outline:none;min-width:0;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.mwp-qty-input::-webkit-outer-spin-button,.mwp-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mwp-qty-input:focus{border-color:#3b82f6;background:#fff}.mwp-unit-chips{display:flex;gap:8px;flex-wrap:wrap}.mwp-unit-chip{padding:7px 16px;border-radius:20px;border:1px solid #d1d5db;background:#f9fafb;font-size:14px;color:#374151;cursor:pointer;transition:all .15s;font-weight:500}.mwp-unit-chip--active{background:#2563eb;border-color:#2563eb;color:#fff}.mwp-reason-chips{display:flex;gap:8px;flex-wrap:wrap}.mwp-reason-chip{padding:8px 14px;border-radius:8px;border:1px solid #d1d5db;background:#f9fafb;font-size:13px;color:#374151;cursor:pointer;transition:all .15s}.mwp-reason-chip--active{background:#fee2e2;border-color:#fca5a5;color:#dc2626;font-weight:600}.mwp-reason-detail{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#111827;background:#f9fafb;outline:none;margin-top:4px}.mwp-reason-detail:focus{border-color:#3b82f6;background:#fff}.mwp-submit-btn{width:100%;padding:14px;background:#dc2626;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:background .15s}.mwp-submit-btn:active{background:#b91c1c}.mwp-submit-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.mwp-warn{text-align:center;font-size:13px;color:#f59e0b;margin:0}.mwp-toast-container{position:fixed;top:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:1000;pointer-events:none;width:max-content;max-width:calc(100vw - 32px)}.mwp-toast{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:14px;font-weight:500;box-shadow:0 4px 12px #00000026;animation:mwp-toast-in .25s ease}.mwp-toast--success{background:#f0fdf4;border:1px solid #86efac;color:#15803d}.mwp-toast--error{background:#fef2f2;border:1px solid #fca5a5;color:#dc2626}@keyframes mwp-toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.app{min-height:100vh;background-color:#f5f5f5}.page{padding:16px 24px 24px}.page-header{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}.page-title{font-size:20px;font-weight:600;margin:0;color:#1a1a1a;white-space:nowrap}.page-description{color:#9ca3af;font-size:13px;margin:0}.card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.button-primary{background-color:#2563eb;color:#fff}.button-primary:hover{background-color:#1d4ed8}.button-secondary{background-color:#f3f4f6;color:#374151}.button-secondary:hover{background-color:#e5e7eb}.input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.input:focus{outline:none;border-color:#2563eb}.label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:12px;background-color:#f9fafb;border-bottom:2px solid #e5e7eb;font-weight:600;color:#374151}.table td{padding:12px;border-bottom:1px solid #e5e7eb;color:#1f2937}.table tbody tr:hover{background-color:#f9fafb}@keyframes loading-spin{to{transform:rotate(360deg)}}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:64px 48px;gap:16px;color:#9ca3af;font-size:13px}.loading:before{content:"";width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:loading-spin .7s linear infinite;flex-shrink:0}.error{color:#dc2626;padding:12px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin:16px 0}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}#root{min-height:100vh}@media(max-width:767px){table{min-width:500px}.table-wrapper,.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.modal-overlay{align-items:flex-end!important}.modal-content{width:100%!important;max-width:100%!important;border-radius:16px 16px 0 0!important;max-height:90dvh!important;overflow-y:auto!important}.page-container,.content-wrapper{padding:12px!important}input[type=text],input[type=number],input[type=date],input[type=email],select,textarea{font-size:16px!important;min-height:44px}button{min-height:44px}}
