.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;animation:moveBackground 20s linear infinite}@keyframes moveBackground{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.login-card{width:440px;box-shadow:0 20px 60px #0000004d;border-radius:16px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;position:relative;z-index:1}.login-card .ant-card-head{background:linear-gradient(135deg,#667eea,#764ba2);border:none;padding:32px 24px}.login-card .ant-card-head-title{text-align:center;font-size:28px;font-weight:700;color:#fff;letter-spacing:1px}.login-card .ant-card-body{padding:40px 32px}.login-card .ant-form-item{margin-bottom:24px}.login-card .ant-input,.login-card .ant-input-password{height:48px;border-radius:8px;border:2px solid #e8e8e8;font-size:15px;transition:all .3s}.login-card .ant-input:hover,.login-card .ant-input-password:hover,.login-card .ant-input:focus,.login-card .ant-input-password:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.login-card .ant-btn-primary{height:48px;font-size:16px;font-weight:600;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 4px 12px #667eea66;transition:all .3s}.login-card .ant-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.login-card .ant-form-item-label>label{font-weight:600;color:#262626}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e8e8e8;flex-shrink:0}.page-header h1{margin:0;font-size:22px;font-weight:600;color:#262626}.page-header .page-subtitle{margin:4px 0 0;font-size:14px;color:#8c8c8c;font-weight:400}.filter-card{margin-bottom:16px}.filter-card .ant-card-body{padding:16px}.filter-card .ant-space{width:100%;row-gap:8px}.table-wrapper{background:#fff;border-radius:8px;padding:16px}.recipe-default-row>td{background:#fbfff5!important}.logo{height:64px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;font-weight:700;letter-spacing:.5px;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);margin:8px;border-radius:8px;transition:all .3s}.logo.collapsed{font-size:18px;letter-spacing:0}.logo:hover{background:linear-gradient(135deg,#ffffff26,#ffffff14)}.content{margin:24px;padding:24px;background:#fff;min-height:calc(100vh - 48px);border-radius:8px;box-shadow:0 1px 2px #00000008}.sider-footer{margin-top:auto;padding:8px 8px 12px;display:flex;flex-direction:column;gap:6px}.sider-divider{margin:8px 8px 4px;border-color:#ffffff1f}.sider-action{color:#ffffffd9;text-align:left;height:36px;border-radius:8px}.sider-action:hover{color:#fff;background:#ffffff14}.ant-layout-sider{background:linear-gradient(180deg,#001529,#002140);box-shadow:2px 0 8px #00000026}.ant-menu-dark{background:transparent}.ant-menu-dark .ant-menu-item{margin:4px 8px;border-radius:8px;transition:all .3s}.ant-menu-dark .ant-menu-item-selected{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d}.ant-menu-dark .ant-menu-item:hover{background:#ffffff14}.ant-menu-dark .ant-menu-item-selected:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f)}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;opacity:0}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.dashboard-page{padding:24px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard-grid{min-height:600px}.dashboard-widget{transition:box-shadow .3s}.dashboard-widget.editing{box-shadow:0 0 0 2px #1890ff}.dashboard-widget .react-resizable-handle{position:absolute;width:20px;height:20px;bottom:0;right:0;cursor:se-resize;z-index:1}.dashboard-widget .react-resizable-handle:after{content:"";position:absolute;right:6px;bottom:6px;width:8px;height:8px;border-right:2px solid rgba(0,0,0,.2);border-bottom:2px solid rgba(0,0,0,.2)}.dashboard-widget .ant-card{height:100%;border-radius:8px;box-shadow:0 1px 2px #0000000d}.dashboard-widget .ant-card-body{height:calc(100% - 57px);padding:16px}@media (max-width: 768px){.dashboard-page{padding:12px}.dashboard-header{flex-direction:column;gap:12px;align-items:flex-start}}.ingredient-page{min-width:0;display:flex;flex-direction:column;height:100%}.ingredient-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e8e8e8;flex-shrink:0}.ingredient-layout{display:flex;gap:16px;min-width:0;flex:1;overflow:hidden}.ingredient-summary{margin-bottom:16px;flex-shrink:0}.ingredient-summary .ant-card-body{padding:12px 16px}.ingredient-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:16px;overflow:hidden}.ingredient-side-card{flex:0 0 220px;overflow:auto}.ingredient-side-card .ant-card-body{padding:16px}.ingredient-filter-card{flex-shrink:0}.ingredient-filter-card .ant-card-body{padding:16px}.ingredient-filter-card .ant-space{width:100%;row-gap:8px}.ingredient-filter-card .ant-space-item{margin-right:0!important}.ingredient-main .ant-table-wrapper{background:#fff;border-radius:8px;padding:16px;flex:1;overflow:hidden;display:flex;flex-direction:column}.ingredient-main .ant-table-wrapper .ant-spin-nested-loading,.ingredient-main .ant-table-wrapper .ant-spin-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.ingredient-main .ant-table-wrapper .ant-table{flex:1;overflow:auto}.ingredient-page-header h1{margin:0;font-size:24px;font-weight:700;color:#262626;display:flex;align-items:center;gap:12px}.ingredient-page-header h1:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px}.category-tag{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.category-spirit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.category-liqueur{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.category-wine{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.category-mixer{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.category-syrup{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff}.category-fresh{background:linear-gradient(135deg,#30cfd0,#330867);color:#fff}.category-garnish{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#333}.category-other{background:linear-gradient(135deg,#d299c2,#fef9d7);color:#333}.alcohol-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#fff2e8;border:1px solid #ffbb96;border-radius:4px;color:#d4380d;font-weight:600;font-size:12px}.ingredient-modal .ant-form-item-label>label{font-weight:600}.ingredient-modal .ant-input,.ingredient-modal .ant-input-number,.ingredient-modal .ant-select-selector{border-radius:6px}.ingredient-material-panel{display:flex;flex-direction:column;gap:10px}.ingredient-material-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.material-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 16px}@media (max-width: 768px){.material-form-grid{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}body{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;background:#f0f2f5}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.ant-card{border-radius:8px;box-shadow:0 1px 2px #00000008;transition:all .3s}.ant-card:hover{box-shadow:0 4px 12px #00000014}.ant-table{border-radius:8px;overflow:hidden}.ant-table-thead>tr>th{background:#fafafa;font-weight:600;color:#262626}.ant-table-tbody>tr:hover>td{background:#f5f7fa}.ant-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 2px 4px #667eea4d}.ant-btn-primary:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 4px 8px #667eea66}.ant-modal-header{border-radius:8px 8px 0 0;background:linear-gradient(135deg,#667eea,#764ba2)}.ant-modal-title{color:#fff;font-weight:600}.ant-modal-close{color:#fff}.ant-modal-close:hover{color:#fff;background:#ffffff1a}.ant-modal-content{border-radius:8px}
