:root{--bg: #fff7ed;--surface: #ffffff;--surface2: #fff1de;--border: #fed7aa;--accent: #ea580c;--accent-dk: #c2410c;--accent-lt: #fb923c;--text: #1c1917;--muted: #78716c;--danger: #dc2626;--shadow: 0 2px 8px rgba(234, 88, 12, .08);--shadow-hover:0 8px 22px rgba(234, 88, 12, .18);--radius: 14px;--radius-sm: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;min-height:100vh;overflow-x:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:#fff;border-bottom:3px solid var(--accent);position:sticky;top:0;z-index:100;gap:12px;box-shadow:0 2px 12px #ea580c1a}.header-brand{display:flex;align-items:center;gap:10px;min-width:0}.header-logo{height:42px;width:auto;object-fit:contain;border-radius:6px;flex-shrink:0}.header-name{font-size:1.3rem;font-weight:800;color:var(--accent-dk);letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-menu{background:var(--accent);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:700;cursor:pointer;transition:background .18s,transform .12s,box-shadow .18s;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 6px #ea580c40}.btn-menu:hover{background:var(--accent-dk);transform:scale(1.03);box-shadow:0 4px 12px #ea580c59}.catalog{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;padding:20px;max-width:1440px;margin:0 auto}.product-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 14px 14px;display:flex;flex-direction:column;align-items:center;gap:10px;transition:transform .18s,border-color .18s,box-shadow .18s;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow)}.product-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow-hover)}.product-card--active{border-color:var(--accent);background:linear-gradient(180deg,#fff,#fff7ed)}.product-image-wrap{width:100%;aspect-ratio:1 / 1;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,#fff1de,#ffe0bc);display:flex;align-items:center;justify-content:center}.product-image{width:100%;height:100%;object-fit:cover}.product-emoji{font-size:3.8rem;line-height:1}.product-name{font-size:.97rem;font-weight:600;text-align:center;line-height:1.3;color:var(--text)}.qty-controls{display:flex;align-items:center;gap:10px}.qty-btn{width:38px;height:38px;border-radius:50%;border:2px solid var(--accent);background:transparent;color:var(--accent);font-size:1.5rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s,transform .1s;display:flex;align-items:center;justify-content:center;line-height:1;flex-shrink:0}.qty-btn:hover:not(:disabled){background:var(--accent);color:#fff;transform:scale(1.1)}.qty-btn:disabled{opacity:.3;cursor:not-allowed;border-color:#d6d3d1;color:#d6d3d1}.qty-value{font-size:1.7rem;font-weight:800;min-width:40px;text-align:center;color:var(--text)}.print-btn{width:100%;padding:10px 8px;border-radius:10px;border:none;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .18s,transform .12s;letter-spacing:.2px}.print-btn--on{background:var(--accent);color:#fff;box-shadow:0 2px 6px #ea580c40}.print-btn--on:hover{background:var(--accent-dk);transform:scale(1.02);box-shadow:0 4px 12px #ea580c59}.print-btn--off{background:#fff1de;color:#a8a29e;cursor:not-allowed}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191759;z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer{position:fixed;top:0;right:0;width:380px;max-width:100vw;height:100dvh;background:var(--surface);border-left:3px solid var(--accent);z-index:200;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden;box-shadow:-8px 0 24px #ea580c1a}.drawer--open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:linear-gradient(135deg,var(--accent),var(--accent-dk));border-bottom:1px solid var(--border);flex-shrink:0}.drawer-title{font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:.3px}.btn-icon{background:#ffffff2e;border:none;color:#fff;font-size:1rem;cursor:pointer;padding:6px 10px;border-radius:6px;transition:background .18s;line-height:1}.btn-icon:hover{background:#ffffff52}.drawer-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-tab{flex:1;padding:12px 8px;background:var(--surface2);border:none;border-bottom:2.5px solid transparent;color:var(--muted);font-size:.88rem;font-weight:600;cursor:pointer;transition:color .18s,border-color .18s,background .18s;letter-spacing:.2px}.drawer-tab:hover{color:var(--text);background:#fce5c5}.drawer-tab--active{color:var(--accent);border-bottom-color:var(--accent);background:var(--surface)}.drawer-body{flex:1;overflow-y:auto;padding:16px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.drawer-section{margin-bottom:24px}.section-title{font-size:.95rem;font-weight:700;color:var(--accent-dk);margin-bottom:12px;padding-bottom:6px;border-bottom:2px solid var(--border)}.field-label{display:block;font-size:.78rem;color:var(--muted);margin:10px 0 4px;text-transform:uppercase;letter-spacing:.5px}.field-input{width:100%;padding:10px 12px;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem;outline:none;transition:border-color .18s,box-shadow .18s}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ea580c26}.field-input::placeholder{color:#a8a29e}.emoji-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.emoji-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:#fff;font-size:1.1rem;cursor:pointer;transition:border-color .15s,transform .12s,background .15s;display:flex;align-items:center;justify-content:center}.emoji-btn:hover{border-color:var(--accent);transform:scale(1.12)}.emoji-btn--active{border-color:var(--accent)!important;background:var(--surface2)!important}.hidden-input{display:none}.file-label{display:block;padding:10px 12px;background:#fff;border:1.5px dashed var(--accent-lt);border-radius:var(--radius-sm);text-align:center;font-size:.85rem;color:var(--accent-dk);cursor:pointer;transition:border-color .18s,background .18s;margin-top:4px}.file-label:hover{border-color:var(--accent);background:var(--surface2)}.logo-preview{display:flex;align-items:center;gap:12px;margin-top:8px;padding:8px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border)}.logo-preview img{max-width:80px;max-height:50px;object-fit:contain;border-radius:4px}.btn-remove{background:none;border:1px solid var(--danger);color:var(--danger);padding:4px 10px;border-radius:6px;font-size:.78rem;cursor:pointer;transition:background .18s,color .18s}.btn-remove:hover{background:var(--danger);color:#fff}.btn-primary{width:100%;padding:12px;margin-top:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:.92rem;font-weight:700;cursor:pointer;transition:background .18s,transform .12s,box-shadow .18s;letter-spacing:.2px;box-shadow:0 2px 6px #ea580c40}.btn-primary:hover{background:var(--accent-dk);transform:scale(1.01);box-shadow:0 4px 12px #ea580c59}.product-list{list-style:none;display:flex;flex-direction:column;gap:6px}.product-list-item{display:flex;align-items:center;gap:10px;padding:9px 10px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);transition:background .15s}.product-list-item:hover{background:#fce5c5}.product-list-icon{font-size:1.2rem;min-width:26px;display:flex;align-items:center}.product-list-thumb{width:26px;height:26px;object-fit:cover;border-radius:4px}.product-list-info{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.product-list-name{font-size:.88rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.product-list-cat{font-size:.72rem;color:var(--accent-dk);background:var(--surface2);padding:1px 6px;border-radius:8px;align-self:flex-start;border:1px solid var(--border)}.btn-danger-icon,.btn-edit-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:5px 7px;border-radius:6px;transition:transform .15s,background .15s;flex-shrink:0}.btn-edit-icon:hover{background:var(--surface2);transform:scale(1.15)}.btn-danger-icon:hover:not(:disabled){background:#fee2e2;transform:scale(1.15)}.btn-danger-icon:disabled{opacity:.3;cursor:not-allowed}.product-list-item--editing{background:var(--surface2)!important;border-color:var(--accent)!important;box-shadow:0 0 0 2px #ea580c26}.form-actions{display:flex;gap:8px;margin-top:14px}.form-actions .btn-primary,.form-actions .btn-secondary{margin-top:0;flex:1}.form-actions .btn-secondary{flex:0 0 auto;padding:12px 18px}.breadcrumb{display:flex;align-items:center;gap:14px;padding:14px 22px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:65px;z-index:50}.btn-back{background:var(--surface2);color:var(--accent-dk);border:1.5px solid var(--border);padding:8px 14px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .18s,transform .12s}.btn-back:hover{background:var(--border);transform:translate(-2px)}.breadcrumb-title{font-size:1.1rem;font-weight:700;color:var(--text)}.category-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:18px 14px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow);font-family:inherit}.category-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:var(--shadow-hover);background:linear-gradient(180deg,#fff,#fff7ed)}.category-image-wrap{width:100%;aspect-ratio:1 / 1;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,var(--accent-lt),var(--accent));display:flex;align-items:center;justify-content:center}.category-image{width:100%;height:100%;object-fit:cover}.category-emoji{font-size:4.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.category-name{font-size:1.05rem;font-weight:700;color:var(--text);text-align:center}.category-count{font-size:.78rem;color:var(--accent-dk);background:var(--surface2);padding:2px 10px;border-radius:12px;border:1px solid var(--border)}.empty-catalog{grid-column:1 / -1;text-align:center;padding:60px 20px;color:var(--muted);font-size:1rem;line-height:1.6}select.field-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ea580c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:36px}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191773;z-index:300;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .18s ease}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(520px,calc(100vw - 28px));max-height:calc(100vh - 40px);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:0 20px 60px #00000040;z-index:301;display:flex;flex-direction:column;overflow:hidden;animation:modalIn .22s cubic-bezier(.34,1.3,.64,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;flex-shrink:0}.modal-title{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700}.modal-thumb{width:36px;height:36px;border-radius:8px;object-fit:cover;border:2px solid rgba(255,255,255,.4)}.modal-emoji{font-size:1.6rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff2e;border-radius:8px}.modal-body{padding:16px 18px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:18px}.modal-section{display:flex;flex-direction:column;gap:8px}.modal-section-title{font-size:.92rem;font-weight:700;color:var(--accent-dk);text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid var(--border);padding-bottom:4px}.modal-hint{font-size:.78rem;color:var(--muted);margin-top:-2px}.qty-row{display:flex;align-items:center;justify-content:center;gap:16px;padding:6px 0}.modal-qty{font-size:1.6rem;font-weight:700;color:var(--text);min-width:50px;text-align:center}.ing-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}.ing-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:.88rem;-webkit-user-select:none;user-select:none;transition:background .15s,border-color .15s}.ing-item:hover{border-color:var(--accent-lt)}.ing-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.ing-name{flex:1}.ing-item--removed{background:#fff;border-color:#fecaca}.ing-item--removed .ing-name{text-decoration:line-through;color:var(--muted)}.ing-tag-removed{font-size:.65rem;font-weight:700;background:var(--danger);color:#fff;padding:2px 6px;border-radius:4px;letter-spacing:.5px}.extra-input-row{display:flex;gap:6px}.extra-input-row .field-input{flex:1}.btn-add-extra{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:0 14px;font-weight:700;font-size:.85rem;cursor:pointer;white-space:nowrap;transition:background .15s}.btn-add-extra:hover{background:var(--accent-dk)}.extra-list{list-style:none;display:flex;flex-direction:column;gap:4px;margin-top:4px}.extra-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.88rem}.modal-textarea{resize:vertical;min-height:50px;font-family:inherit}.modal-footer{display:flex;gap:10px;padding:14px 18px;background:var(--surface2);border-top:1px solid var(--border);flex-shrink:0}.btn-secondary{flex:1;background:#fff;color:var(--text);border:1.5px solid var(--border);border-radius:10px;padding:12px;font-weight:600;font-size:.92rem;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--surface2)}.modal-print-btn{flex:2;margin-top:0!important}.empty-msg{color:var(--muted);font-size:.85rem;text-align:center;padding:12px 0}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;border:1px solid var(--accent-dk);padding:11px 22px;border-radius:30px;font-size:.88rem;font-weight:600;z-index:500;white-space:nowrap;box-shadow:0 6px 20px #ea580c59;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 600px){.catalog{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}.product-emoji{font-size:2.8rem}.qty-value{font-size:1.4rem}.qty-btn{width:34px;height:34px}.header-name{font-size:1rem}}@media (min-width: 1200px){.catalog{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}
