.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}@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{color:#dc2626}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-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-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-bom-panel{flex:1;min-width:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;display:flex;flex-direction:column}.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.over{background:#eff6ff;outline-color:#93c5fd}.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}.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-indicator{padding:12px 20px;text-align:center;font-size:12px;color:#d1d5db;border-top:1px dashed #e5e7eb;-webkit-user-select:none;user-select:none}.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-name{color:#e5e7eb;font-size:14px;font-weight:500}.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}.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}
