@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--color-primary: #635bff;--color-primary-hover: #4b45c2;--color-text-primary: #3c4257;--color-text-secondary: #697386;--color-text-tertiary: #8792a2;--color-heading: #1a1f36;--bg-primary: #ffffff;--bg-secondary: #f7f9fc;--bg-tertiary: #e3e8ee;--border-color: #e3e8ee;--border-color-hover: #cdd6e0;--border-color-focus: #635bff;--color-success: #057055;--bg-success-light: #dcf5f0;--color-warning: #a35200;--bg-warning-light: #fffceb;--color-danger: #c01048;--bg-danger-light: #fff1f3;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(60, 66, 87, .08), 0 0 0 1px rgba(60, 66, 87, .12);--shadow-md: 0 4px 6px rgba(60, 66, 87, .08), 0 0 0 1px rgba(60, 66, 87, .12);--shadow-lg: 0 12px 24px rgba(60, 66, 87, .08), 0 0 0 1px rgba(60, 66, 87, .08);--shadow-focus: 0 0 0 4px rgba(99, 91, 255, .15);--header-height: 64px;--sidebar-width: 240px}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);color:var(--color-text-primary);background-color:var(--bg-secondary);line-height:1.5;-webkit-font-smoothing:antialiased}body,#root{min-height:100vh;min-height:100dvh}#root{isolation:isolate}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;color:var(--color-heading)}button{font-family:inherit;font-size:14px;cursor:pointer;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:#fff;padding:8px 12px;transition:all .2s ease;color:var(--color-text-primary);box-shadow:var(--shadow-sm);border:none}button,input,select,textarea{touch-action:manipulation}button:hover{background:var(--bg-secondary);box-shadow:0 2px 5px #3c42571f,0 0 0 1px #3c42571f;transform:translateY(-1px)}button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}button.primary{background:var(--color-primary);color:#fff;box-shadow:0 1px 2px #00000029,0 0 0 1px #00000014}button.primary:hover{background:var(--color-primary-hover);opacity:1;box-shadow:0 2px 5px #0003,0 0 0 1px #00000014}input,select,textarea{font-family:inherit;font-size:14px;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;background:#fff;color:var(--color-text-primary);transition:all .2s;box-shadow:0 1px 2px #0000000d}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.card{background:#fff;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:none}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;background:var(--bg-secondary)}.badge-success{background:var(--bg-success-light);color:var(--color-success)}.badge-warning{background:var(--bg-warning-light);color:var(--color-warning)}.badge-danger{background:var(--bg-danger-light);color:var(--color-danger)}table{width:100%;border-collapse:separate;border-spacing:0;margin:var(--space-md) 0}th{text-align:left;font-size:12px;text-transform:uppercase;color:var(--color-text-secondary);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color);font-weight:600;letter-spacing:.025em}td{padding:var(--space-md);border-bottom:1px solid var(--border-color);font-size:14px;color:var(--color-text-primary)}.sticky-header{position:sticky;top:0;background:#fff;z-index:100;border-bottom:1px solid var(--border-color);padding:var(--space-sm) var(--space-xl);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm)}.standard-table{width:100%;border-collapse:collapse}.standard-table th{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--space-sm) var(--space-md);font-size:11px;text-transform:uppercase;color:var(--color-text-secondary);font-weight:600;text-align:left}.standard-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color);vertical-align:middle}.standard-table tr:hover td{background-color:var(--bg-secondary)}.btn-text{border:none;background:none;padding:0;cursor:pointer;font-weight:500;font-size:14px;color:var(--color-text-secondary);transition:color .2s;box-shadow:none}.btn-text:hover{color:var(--color-primary);background:none;transform:none;box-shadow:none}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--color-text-tertiary);font-style:normal}@media print{body{background:#fff!important;color:#000!important}nav,.no-print,button:not(.print-visible),input[type=text],textarea{display:none!important}.card{box-shadow:none!important;border:1px solid #ccc!important;break-inside:avoid}@page{size:A4;margin:12mm}.standard-table th{color:#000!important;border-bottom:2px solid black!important}.standard-table td{border-bottom:1px solid #eee!important}}@media (max-width: 768px){body{font-size:14px}button,input,select,textarea{min-height:44px}input,select,textarea{font-size:16px}h1{font-size:22px!important}h2{font-size:17px!important}h3{font-size:15px!important}.card{padding:var(--space-md);border-radius:var(--radius-sm)}.table-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-md));padding:0 var(--space-md)}.standard-table{min-width:600px}th,td{padding:var(--space-xs) var(--space-sm);font-size:13px}.sticky-header{padding:var(--space-sm) var(--space-md)!important;flex-wrap:wrap;gap:var(--space-sm)}.tabs-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;scrollbar-width:none}.tabs-scroll::-webkit-scrollbar{display:none}.grid-responsive-2,.grid-responsive-3{grid-template-columns:1fr!important}.grid-responsive-4{grid-template-columns:repeat(2,1fr)!important}.hide-on-mobile{display:none!important}.empty-state{padding:var(--space-lg)}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1f3652;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:199;animation:fadeIn .2s ease}.mobile-topbar{position:fixed;top:0;left:0;right:0;z-index:180;display:flex;align-items:center;gap:12px;padding:calc(10px + env(safe-area-inset-top)) 14px 10px;background:#f7f9fceb;border-bottom:1px solid rgba(227,232,238,.9);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-topbar__content{min-width:0;display:flex;flex-direction:column;gap:2px}.mobile-topbar__eyebrow{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary)}.mobile-topbar__title{min-width:0;font-size:16px;font-weight:600;color:var(--color-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-hamburger{position:relative;z-index:1;width:44px;height:44px;min-width:44px;border-radius:12px;background:#fff;border:1px solid var(--border-color);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;padding:0}.app-main{width:100%;overflow-x:hidden}.auth-shell{min-height:100vh;min-height:100dvh;padding:calc(18px + env(safe-area-inset-top)) 16px calc(20px + env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:center}.auth-card{width:100%;margin:0 auto;padding:20px!important;border-radius:16px!important;box-shadow:var(--shadow-md)}.auth-mode-switch{display:grid!important;grid-template-columns:1fr}}@media (min-width: 769px){.mobile-hamburger,.mobile-overlay{display:none!important}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ingredient-search-wrap{position:relative;width:100%}.ingredient-search-popover{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:280px;overflow-y:auto;z-index:60;border:1px solid var(--border-color)}.ingredient-search-item{padding:10px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:background .2s}.ingredient-search-item:hover,.ingredient-search-item.highlighted{background:var(--bg-secondary);color:var(--color-primary)}.ingredient-search-item.disabled{cursor:default;opacity:.5}.catalog-component-add{display:flex;flex-direction:column;gap:10px}.catalog-component-add-main{display:grid;grid-template-columns:minmax(260px,1.8fr) auto auto;gap:10px;align-items:center}.catalog-component-search-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--bg-primary)}.catalog-component-quantity,.recipe-quantity-cell{display:inline-flex;align-items:center;gap:8px}.catalog-component-unit-chip{display:inline-flex;align-items:center;justify-content:center;min-width:56px;padding:7px 10px;border-radius:999px;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--color-text-secondary);font-size:12px;font-weight:600;text-transform:uppercase}.catalog-component-add-hint{font-size:12px;color:var(--color-text-secondary)}@media (max-width: 900px){.catalog-component-add-main{grid-template-columns:1fr}.catalog-component-quantity,.recipe-quantity-cell{justify-content:flex-start}}.App{text-align:left}.global-search-shell{position:sticky;top:0;z-index:140;margin-bottom:24px;padding-top:4px}.global-search-shell.is-mobile{top:calc(70px + env(safe-area-inset-top))}.global-search-card{position:relative;display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#fffffff5,#f7f9fcf0),#fff;box-shadow:0 18px 36px #3c425714,0 0 0 1px #635bff14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.global-search-card__icon{width:38px;height:38px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#635bff1f;color:var(--color-primary);flex-shrink:0}.global-search-card__field{flex:1;min-width:0}.global-search-card__label{display:block;margin-bottom:4px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--color-text-tertiary)}.global-search-card__input{width:100%;border:none;background:transparent;box-shadow:none;padding:0;font-size:16px;font-weight:600}.global-search-card__input:focus{box-shadow:none}.global-search-card__shortcut{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#0000000a;color:var(--color-text-secondary);font-size:12px;font-weight:600}.global-search-card__clear{flex-shrink:0;border:none;background:#0000000a;box-shadow:none;color:var(--color-text-secondary)}.global-search-panel{position:absolute;top:calc(100% + 12px);left:0;right:0;max-height:min(68vh,720px);overflow:auto;padding:14px;border-radius:20px;background:#fffffffa;box-shadow:0 28px 56px #1a1f3629,0 0 0 1px #635bff14;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.global-search-panel__footer{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border-color)}.global-search-panel__hint{color:var(--color-text-secondary);font-size:12px}.global-search-results{display:grid;gap:14px}.global-search-results.is-page{gap:18px}.global-search-results__empty,.global-search-results__error,.global-search-results__loading{padding:18px 16px;border-radius:16px;border:1px dashed var(--border-color);background:#f7f9fcb8;color:var(--color-text-secondary);font-size:14px}.global-search-results__error{border-style:solid;color:var(--color-danger);background:#fff3f4}.global-search-section{border:1px solid rgba(227,232,238,.9);border-radius:18px;background:#fff;overflow:hidden}.global-search-section__header{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid rgba(227,232,238,.9);background:linear-gradient(180deg,#f7f9fceb,#ffffffeb)}.global-search-section__title{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary)}.global-search-section__count{font-size:12px;color:var(--color-text-tertiary);font-weight:600}.global-search-section__items{display:grid}.global-search-row{width:100%;display:flex;align-items:flex-start;gap:12px;padding:14px;border:none;border-radius:0;background:transparent;box-shadow:none;text-align:left}.global-search-row+.global-search-row{border-top:1px solid rgba(227,232,238,.8)}.global-search-row:hover{background:#635bff0d;transform:none;box-shadow:none}.global-search-row.is-active{background:#635bff14}.global-search-row.is-active .global-search-row__icon{background:#635bff2e}.global-search-row:focus-visible{outline:2px solid rgba(99,91,255,.24);outline-offset:-2px}.global-search-row__icon{width:38px;height:38px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:#635bff1f;color:var(--color-primary);font-size:18px}.global-search-row__content{min-width:0;flex:1;display:grid;gap:4px}.global-search-row__title{font-size:15px;font-weight:700;color:var(--color-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-search-row__subtitle{font-size:13px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-search-row__meta{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--color-text-tertiary)}.global-search-row__meta-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:var(--bg-secondary)}.global-search-highlight{padding:0;background:#ffd35c73;color:inherit;border-radius:4px}.global-search-page{display:grid;gap:18px}.global-search-page__intro{padding:24px}.global-search-page__filters{display:flex;flex-wrap:wrap;gap:8px}.global-search-filter{border:1px solid var(--border-color);background:#fff;color:var(--color-text-secondary);box-shadow:none}.global-search-filter.is-active{border-color:transparent;background:var(--color-primary);color:#fff}.global-search-page__summary{display:flex;flex-wrap:wrap;gap:8px;color:var(--color-text-secondary);font-size:13px}@media (max-width: 900px){.global-search-card{padding:12px 14px;border-radius:16px}.global-search-card__shortcut{display:none}.global-search-panel{padding:12px;border-radius:18px}.global-search-row{padding:12px}}
