:root{--bg: #e8f5e9;--bg-warm: #fff8e1;--surface: #ffffff;--primary: #43a047;--primary-dark: #2e7d32;--primary-light: #81c784;--accent: #ff9800;--accent-light: #ffb74d;--text: #1b5e20;--text-muted: #558b2f;--error: #c62828;--touch-min: 48px;--radius: 20px;--radius-big: 28px;--shadow: 0 4px 16px rgba(46, 125, 50, .15);--shadow-soft: 0 2px 12px rgba(0,0,0,.06);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font);font-size:18px;color:var(--text);background:linear-gradient(180deg,var(--bg) 0%,var(--bg-warm) 100%);background-attachment:fixed;overflow-x:hidden;user-select:none;-webkit-user-select:none}button,a,[role=button]{min-height:var(--touch-min);min-width:var(--touch-min)}button{font-family:inherit;font-size:1.1rem;cursor:pointer;border:none;border-radius:var(--radius);transition:transform .1s,box-shadow .2s}button:active{transform:scale(.98)}.btn-large{padding:20px 32px;font-size:1.35rem;font-weight:600;border-radius:var(--radius);min-height:64px}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow)}.btn-primary:hover,.btn-primary:focus-visible{background:var(--primary-dark);box-shadow:0 6px 16px #4caf5059}.btn-secondary{background:var(--surface);color:var(--text);border:2px solid #e0e0e0}.page{min-height:100%;padding:24px;padding-bottom:env(safe-area-inset-bottom,24px);display:flex;flex-direction:column;align-items:center;max-width:900px;margin:0 auto}.page-title{font-size:1.75rem;font-weight:700;margin:0 0 24px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.animate-pop{animation:pop .35s ease-out forwards}.animate-slide-up{animation:slideUp .4s ease-out forwards}.qr-scanner-wrap{width:100%;max-width:400px;overflow:hidden;border-radius:var(--radius);background:#000}.qr-scanner-wrap video{max-width:100%}#qr-reader__scan_region{background:#000!important}#qr-reader__dashboard{padding:8px!important}#qr-reader__dashboard_section_csr button{min-height:44px;padding:10px 16px}.page--home{align-items:stretch;padding-bottom:32px}.home-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:0 4px}.home-title{font-size:1.85rem;font-weight:800;margin:0;color:var(--text);letter-spacing:-.02em}.home-cart-link{position:relative;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--surface);border-radius:50%;box-shadow:var(--shadow-soft);text-decoration:none;transition:transform .15s}.home-cart-link:active{transform:scale(.95)}.home-cart-icon{font-size:1.75rem}.home-cart-badge{position:absolute;top:-4px;right:-4px;min-width:24px;height:24px;padding:0 6px;background:var(--accent);color:#fff;font-size:.85rem;font-weight:700;border-radius:12px;display:flex;align-items:center;justify-content:center;animation:pop .3s ease-out}.home-scan{margin-bottom:28px}.btn-scan{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;max-width:320px;margin:0 auto;padding:22px 28px;background:var(--primary);color:#fff;font-size:1.4rem;font-weight:700;border-radius:var(--radius-big);box-shadow:var(--shadow);text-decoration:none;transition:transform .1s,box-shadow .2s;border:none;cursor:pointer}.btn-scan:hover,.btn-scan:focus-visible{background:var(--primary-dark);box-shadow:0 8px 24px #2e7d324d}.btn-scan:active{transform:scale(.98)}.btn-scan-icon{font-size:1.75rem}.home-section{width:100%;max-width:560px;margin:0 auto 28px}.home-section-title{font-size:1.25rem;font-weight:700;color:var(--text);margin:0 0 8px}.home-section-sub{font-size:.95rem;color:var(--text-muted);margin:0 0 14px}.home-categories{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.home-category-card{display:flex;align-items:center;justify-content:center;min-height:56px;padding:14px 16px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);font-size:1.05rem;font-weight:600;color:var(--text);text-decoration:none;transition:transform .1s,box-shadow .15s}.home-category-card:hover,.home-category-card:focus-visible{box-shadow:0 4px 16px #0000001a}.home-category-card:active{transform:scale(.98)}.home-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.home-quick-item{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;padding:14px 8px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);border:3px solid transparent;font-family:inherit;cursor:pointer;transition:transform .1s,border-color .2s,box-shadow .2s}.home-quick-item:hover,.home-quick-item:focus-visible{border-color:var(--primary-light);box-shadow:var(--shadow)}.home-quick-item:active{transform:scale(.97)}.home-quick-item.is-adding{border-color:var(--primary);background:#e8f5e9;animation:quickAdd .4s ease-out}@keyframes quickAdd{0%{transform:scale(1)}40%{transform:scale(1.08)}to{transform:scale(1)}}.home-quick-emoji{font-size:2.25rem;line-height:1;margin-bottom:6px}.home-quick-name{font-size:.9rem;font-weight:600;color:var(--text);text-align:center;line-height:1.2}.home-quick-price{font-size:.85rem;color:var(--text-muted);margin-top:2px}.home-footer{margin-top:auto;padding-top:24px;text-align:center}.home-parent-link{font-size:.9rem;color:var(--text-muted);text-decoration:none}.page--category{padding-bottom:32px}.category-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;width:100%;max-width:560px}.btn-back{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--surface);border-radius:50%;box-shadow:var(--shadow-soft);font-size:1.5rem;text-decoration:none;color:var(--text);flex-shrink:0}.category-header .page-title{margin:0;flex:1}.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:100%;max-width:560px;margin-bottom:24px}.category-card{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;padding:18px 12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);border:3px solid transparent;font-family:inherit;cursor:pointer;transition:transform .1s,border-color .2s,box-shadow .2s}.category-card:hover,.category-card:focus-visible{border-color:var(--primary-light);box-shadow:var(--shadow)}.category-card:active{transform:scale(.98)}.category-card.is-adding{border-color:var(--primary);background:#e8f5e9;animation:quickAdd .4s ease-out}.category-card-emoji{font-size:2.75rem;line-height:1;margin-bottom:8px}.category-card-name{font-size:1rem;font-weight:600;color:var(--text);text-align:center}.category-card-price{font-size:.95rem;color:var(--text-muted);margin-top:4px}.page--category .home-link{text-decoration:none}.page--cart{max-width:520px}.cart-list{list-style:none;padding:0;margin:0 0 24px;width:100%;display:flex;flex-direction:column;gap:12px}.cart-item{display:flex;align-items:center;gap:12px;padding:16px 18px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.cart-item-emoji{font-size:2.25rem;line-height:1}.cart-item-name{flex:1;font-weight:600;font-size:1.1rem;color:var(--text)}.cart-item-qty{font-size:.95rem;color:var(--text-muted)}.cart-item-subtotal{font-weight:700;font-size:1.05rem;color:var(--text)}.cart-item-remove{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffebee;color:var(--error);border-radius:50%;font-size:1.2rem;flex-shrink:0}.cart-subtotal{font-size:1.4rem;font-weight:800;margin-bottom:24px;color:var(--text)}.cart-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);padding:16px 28px;background:var(--primary-dark);color:#fff;font-size:1.25rem;font-weight:700;border-radius:var(--radius-big);box-shadow:var(--shadow);z-index:1000;pointer-events:none}.quantity-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b5e20d9;z-index:1500;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease-out}.quantity-picker{background:var(--surface);border-radius:var(--radius-big);padding:28px 24px;width:100%;max-width:340px;box-shadow:var(--shadow);animation:pop .25s ease-out}.quantity-picker-title{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1.4rem;font-weight:700;color:var(--text);margin:0 0 6px}.quantity-picker-emoji{font-size:2rem}.quantity-picker-price{text-align:center;color:var(--text-muted);font-size:1rem;margin:0 0 20px}.quantity-picker-controls{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:16px}.quantity-picker-btn{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;background:var(--primary-light);color:var(--primary-dark);border-radius:50%;transition:transform .1s}.quantity-picker-btn:active{transform:scale(.95)}.quantity-picker-value{font-size:1.75rem;font-weight:700;min-width:2.5ch;text-align:center}.quantity-picker-subtotal{text-align:center;font-size:1.15rem;font-weight:700;color:var(--text);margin:0 0 20px}.quantity-picker-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.scanner-success-flash{position:fixed;top:0;right:0;bottom:0;left:0;background:#2e7d32b3;z-index:500;pointer-events:none;animation:scannerFlash .6s ease-out forwards}@keyframes scannerFlash{0%{opacity:1}70%{opacity:1}to{opacity:0}}.scanner-hint{font-size:1.1rem;color:var(--text-muted);text-align:center;margin-bottom:16px;max-width:320px}.scanner-error{color:var(--error);margin-bottom:12px;text-align:center;font-weight:600}.scanner-added{color:var(--primary);font-weight:700;margin-bottom:8px}.scanner-actions{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.scanner-unavailable{text-align:center;max-width:360px;margin-top:16px}.scanner-unavailable-emoji{font-size:3rem;margin:0 0 16px}.scanner-unavailable-title{font-size:1.25rem;font-weight:700;color:var(--text);margin:0 0 12px}.scanner-unavailable-p{font-size:1rem;color:var(--text-muted);line-height:1.45;margin:0 0 24px}.scanner-unavailable-p strong{color:var(--text)}.empty-state{text-align:center;padding:32px 24px}.empty-state-emoji{font-size:4rem;line-height:1;margin-bottom:16px;display:block}.empty-state-title{font-size:1.35rem;font-weight:700;color:var(--text);margin:0 0 8px}.empty-state-p{color:var(--text-muted);margin:0 0 24px;font-size:1.05rem}.page--payment{max-width:440px}.payment-total-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px;margin-bottom:20px;width:100%}.payment-total-label{font-size:1rem;color:var(--text-muted);margin:0 0 4px}.payment-total-amount{font-size:2rem;font-weight:800;color:var(--text)}.payment-method-label{font-size:1rem;color:var(--text-muted);margin:0 0 10px;text-align:center}.payment-method-row{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;justify-content:center}.payment-method-btn{flex:1;min-width:120px}.payment-cash-mode-toggle{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}.payment-cash-mode-label{font-size:.95rem;color:var(--text-muted);margin-right:4px}.payment-cash-mode-btn{font-family:inherit;font-size:.95rem;font-weight:600;padding:10px 20px;border-radius:999px;border:2px solid #e0e0e0;background:var(--surface);color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.payment-cash-mode-btn:hover{border-color:var(--primary-light);color:var(--text)}.payment-cash-mode-btn--on{background:var(--primary);border-color:var(--primary);color:#fff}.payment-back-link{display:inline-flex;align-items:center;justify-content:center;margin-top:24px;padding:16px 24px;font-size:1.1rem;font-weight:600;color:var(--text-muted);text-decoration:none;border-radius:var(--radius);transition:color .15s,background .15s}.payment-back-link:hover,.payment-back-link:focus-visible{color:var(--text);background:var(--surface);box-shadow:var(--shadow-soft)}.payment-cash-learning{width:100%}.payment-cash-instruction{font-size:1rem;color:var(--text-muted);text-align:center;margin:0 0 16px;line-height:1.4}.payment-cash-money{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:20px 16px;margin-bottom:16px}.payment-cash-section-label{font-size:.9rem;font-weight:700;color:var(--text-muted);margin:0 0 10px;text-align:center}.payment-cash-section-label:not(:first-child){margin-top:18px}.payment-cash-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.payment-cash-coin-btn{font-family:inherit;font-size:1.1rem;font-weight:700;border:none;border-radius:var(--radius);cursor:pointer;transition:transform .1s,box-shadow .15s}.payment-cash-coin-btn:active{transform:scale(.96)}.payment-cash-bill{min-width:56px;padding:14px 16px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:var(--primary-dark);border:2px solid var(--primary-light)}.payment-cash-bill:hover,.payment-cash-bill:focus-visible{box-shadow:0 2px 12px #2e7d3240}.payment-cash-coin{min-width:52px;padding:12px 14px;background:linear-gradient(135deg,#fff8e1,#ffecb3);color:#f57c00;border:2px solid var(--accent-light)}.payment-cash-coin:hover,.payment-cash-coin:focus-visible{box-shadow:0 2px 12px #ff98004d}.payment-cash-given-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:16px 20px;margin-bottom:12px;text-align:center}.payment-cash-given-label{font-size:.95rem;color:var(--text-muted);margin:0 0 4px}.payment-cash-given-amount{font-size:1.5rem;font-weight:800;color:var(--text)}.payment-cash-change-card{background:#e8f5e9;border:2px solid var(--primary-light);border-radius:var(--radius);padding:16px 20px;margin-bottom:20px;text-align:center}.payment-cash-change-label{font-size:.95rem;font-weight:700;color:var(--primary-dark);margin:0 0 4px}.payment-cash-change-amount{font-size:1.4rem;font-weight:800;color:var(--primary-dark);margin:0 0 4px}.payment-cash-change-words{font-size:1rem;color:var(--text-muted);margin:0;font-style:italic}.payment-cash-complete{width:100%}.page--change{max-width:440px}.payment-change-target-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:18px 20px;margin-bottom:20px;text-align:center}.payment-change-card{background:#e8f5e9;border:2px solid var(--primary-light);border-radius:var(--radius);padding:28px 24px;margin-bottom:24px;text-align:center}.payment-change-big{font-size:1.4rem;font-weight:800;color:var(--primary-dark);margin:0 0 8px}.payment-change-sub{font-size:1rem;color:var(--text-muted);margin:0}.payment-change-success{margin-top:20px;text-align:center}.payment-change-success-text{font-size:1.35rem;font-weight:700;color:var(--primary-dark);margin:0 0 16px}.receipt-paper{width:100%;max-width:380px;background:var(--surface);border-radius:4px;box-shadow:0 2px 8px #00000014,0 0 0 1px #0000000a;padding:28px 24px;margin-bottom:24px;position:relative}.receipt-paper:before{content:"";position:absolute;top:0;left:0;right:0;height:8px;background:repeating-linear-gradient(transparent,transparent 2px,#e0e0e0 2px,#e0e0e0 4px);border-radius:4px 4px 0 0}.receipt-store{font-size:1.25rem;font-weight:800;color:var(--text);margin:0 0 4px}.receipt-date{font-size:.9rem;color:var(--text-muted);margin:0 0 20px}.receipt-line{display:flex;justify-content:space-between;margin-bottom:10px;font-size:1rem}.receipt-total-row{display:flex;justify-content:space-between;font-weight:700;font-size:1.2rem;margin-top:16px;padding-top:16px;border-top:2px dashed #e0e0e0}.receipt-payment-type{font-size:.9rem;color:var(--text-muted);margin-top:12px}.hint-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b5e20d9;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;animation:fadeIn .3s ease-out}.hint-overlay-content{background:var(--surface);border-radius:var(--radius-big);padding:32px 28px;max-width:360px;text-align:center;box-shadow:var(--shadow)}.hint-overlay-title{font-size:1.5rem;font-weight:800;color:var(--text);margin:0 0 16px}.hint-overlay-p{font-size:1.1rem;color:var(--text-muted);margin:0 0 24px;line-height:1.4}.hint-overlay-btn{width:100%;padding:18px 24px;font-size:1.2rem;font-weight:700}.skip-link{position:absolute;top:-60px;left:12px;padding:12px 20px;background:var(--primary);color:#fff;font-weight:600;border-radius:var(--radius);text-decoration:none;z-index:100;transition:top .2s}.skip-link:focus{top:12px;outline:3px solid var(--accent);outline-offset:2px}.settings-list{display:flex;flex-direction:column;gap:20px;max-width:420px;width:100%}.settings-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px;cursor:pointer;padding:16px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.settings-checkbox{width:24px;height:24px;flex-shrink:0;margin-top:2px}.settings-row>span:first-of-type{font-weight:600;color:var(--text)}.settings-desc{width:100%;font-size:.9rem;color:var(--text-muted);margin-top:-4px;padding-left:36px}.page--store-select{display:flex;flex-direction:column;align-items:center;padding:24px 20px;min-height:100%;background:linear-gradient(180deg,#f5f5f5,#eee,#e8f5e9)}.store-select-header{margin-bottom:32px;text-align:center}.store-select-title{font-size:1.5rem;font-weight:700;color:var(--text);margin:0}.store-select-subtitle{font-size:1.05rem;color:var(--text-muted);margin:8px 0 0}.store-select-grid{display:flex;flex-direction:column;gap:20px;width:100%;max-width:360px}.store-select-card{display:flex;flex-direction:column;align-items:center;padding:28px 24px;border-radius:var(--radius-big);text-decoration:none;color:var(--text);background:var(--surface);box-shadow:var(--shadow-soft);border:3px solid transparent;transition:transform .15s,box-shadow .2s}.store-select-card:active,.store-select-card:hover{transform:scale(1.03);box-shadow:0 6px 20px #0000001f}.store-select-card--grocery{border-color:var(--primary-light);background:linear-gradient(135deg,#e8f5e9 0%,var(--surface) 100%)}.store-select-card--bakery{border-color:#ffccbc;background:linear-gradient(135deg,#fff3e0 0%,var(--surface) 100%)}.store-select-card--hardware{border-color:#b0bec5;background:linear-gradient(135deg,#eceff1 0%,var(--surface) 100%)}.store-select-emoji{font-size:3.25rem;margin-bottom:12px;display:block;transition:transform .2s}.store-select-card:active .store-select-emoji,.store-select-card:hover .store-select-emoji{transform:scale(1.08)}.store-select-name{font-size:1.35rem;font-weight:700;margin-bottom:4px}.store-select-desc{font-size:.95rem;color:var(--text-muted);text-align:center}.store-select-footer{margin-top:auto;padding-top:24px}.page--bakery-home{display:flex;flex-direction:column;min-height:100%;background:linear-gradient(180deg,#fff8e1,#ffecb3,#ffe0b2);position:relative}.bakery-home-awning{position:absolute;top:0;left:0;right:0;height:8px;background:repeating-linear-gradient(90deg,#8d6e63,#8d6e63 12px,#a1887f 12px,#a1887f 24px);border-radius:0 0 8px 8px;opacity:.9}.bakery-home-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:12px}.bakery-home-title{font-size:1.5rem;font-weight:700;margin:0;color:#5d4037;display:flex;align-items:center;gap:8px}.bakery-home-title-emoji{font-size:1.75rem}.bakery-home-back{padding:12px 16px;font-size:1.2rem;text-decoration:none;color:#5d4037;font-weight:600;border-radius:var(--radius);background:#fffc;min-height:var(--touch-min);display:inline-flex;align-items:center}.bakery-home-section{flex:1;padding:24px 20px}.bakery-home-section-title{font-size:1.2rem;font-weight:600;color:#5d4037;margin:0 0 20px;text-align:center}.bakery-home-cards{display:flex;flex-direction:column;gap:20px;max-width:360px;margin:0 auto}.bakery-home-card{display:flex;flex-direction:column;align-items:center;padding:24px 20px;border-radius:var(--radius-big);text-decoration:none;color:#5d4037;background:var(--surface);box-shadow:0 4px 20px #5d40371f;border:3px solid #d7ccc8;transition:transform .15s,box-shadow .2s}.bakery-home-card:active,.bakery-home-card:hover{transform:scale(1.02);box-shadow:0 8px 28px #5d403733}.bakery-home-card--bake{border-color:#bcaaa4;background:linear-gradient(145deg,#fff8e1 0%,var(--surface) 100%)}.bakery-home-card--shop{border-color:#a5d6a7;background:linear-gradient(145deg,#e8f5e9 0%,var(--surface) 100%)}.bakery-home-card-emoji{font-size:2.75rem;margin-bottom:8px;display:block;transition:transform .2s}.bakery-home-card:active .bakery-home-card-emoji,.bakery-home-card:hover .bakery-home-card-emoji{transform:scale(1.1)}.bakery-home-card-name{font-size:1.3rem;font-weight:700;margin-bottom:4px}.bakery-home-card-desc{font-size:.9rem;color:#6d4c41;text-align:center}.bakery-home-footer{padding:16px 20px;text-align:center}.page--hardware-home{display:flex;flex-direction:column;min-height:100%;background:linear-gradient(180deg,#eceff1,#cfd8dc,#b0bec5)}.hardware-home-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:12px}.hardware-home-title{font-size:1.5rem;font-weight:700;margin:0;color:#37474f}.hardware-home-back{padding:12px 16px;font-size:1.2rem;text-decoration:none;color:#37474f;font-weight:600;border-radius:var(--radius);background:#ffffffe6;min-height:var(--touch-min);display:inline-flex;align-items:center}.hardware-home-section{flex:1;padding:24px 20px}.hardware-home-section-title{font-size:1.2rem;font-weight:600;color:#37474f;margin:0 0 20px;text-align:center}.hardware-home-cards{display:flex;flex-direction:column;gap:20px;max-width:360px;margin:0 auto}.hardware-home-card{display:flex;flex-direction:column;align-items:center;padding:24px 20px;border-radius:var(--radius-big);text-decoration:none;color:#37474f;background:var(--surface);box-shadow:0 4px 20px #37474f1f;border:3px solid #b0bec5;transition:transform .15s,box-shadow .2s}.hardware-home-card:active,.hardware-home-card:hover{transform:scale(1.02);box-shadow:0 6px 24px #37474f2e}.hardware-home-card--build{border-color:#ffb74d;background:linear-gradient(145deg,#fff8e1 0%,var(--surface) 100%)}.hardware-home-card--repair{border-color:#8d6e63;background:linear-gradient(145deg,#efebe9 0%,var(--surface) 100%)}.hardware-home-card--paint{border-color:#ab47bc;background:linear-gradient(145deg,#f3e5f5 0%,var(--surface) 100%)}.hardware-home-card--measure{border-color:#5c6bc0;background:linear-gradient(145deg,#e8eaf6 0%,var(--surface) 100%)}.hardware-home-card--shop{border-color:#81c784;background:linear-gradient(145deg,#e8f5e9 0%,var(--surface) 100%)}.hardware-home-card-emoji{font-size:2.75rem;margin-bottom:8px;display:block}.hardware-home-card-name{font-size:1.3rem;font-weight:700;margin-bottom:4px}.hardware-home-card-desc{font-size:.9rem;color:#546e7a;text-align:center}.hardware-home-footer{padding:16px 20px;text-align:center}.page--build-list{padding:20px;min-height:100%;background:linear-gradient(180deg,#eceff1,#cfd8dc)}.build-list-header{margin-bottom:16px}.build-list-header .page-title{margin:0;font-size:1.35rem}.build-list-intro{color:#37474f;font-size:1rem;margin:0 0 24px;max-width:360px}.build-list-grid{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.build-list-card{display:flex;flex-direction:column;align-items:center;padding:24px 20px;border-radius:var(--radius-big);text-decoration:none;color:#37474f;background:var(--surface);box-shadow:0 4px 16px #37474f1f;border:3px solid #b0bec5;transition:transform .1s,box-shadow .2s}.build-list-card:active,.build-list-card:hover{transform:scale(1.01);box-shadow:0 6px 20px #37474f26}.build-list-card-emoji{font-size:2.5rem;margin-bottom:8px;display:block}.build-list-card-name{font-size:1.2rem;font-weight:700;margin-bottom:2px}.build-list-card-desc{font-size:.9rem;color:#546e7a;margin-bottom:4px}.build-list-card-steps{font-size:.85rem;color:var(--text-muted)}.page--build{display:flex;flex-direction:column;min-height:100%;padding:20px;background:linear-gradient(180deg,#eceff1,#cfd8dc)}.build-header{margin-bottom:16px}.build-header .btn-back{margin-bottom:8px}.build-project-name{font-size:1.25rem;font-weight:700;color:#37474f;margin:0 0 4px}.build-progress{font-size:.95rem;color:#546e7a;margin:0}.build-visual{flex-shrink:0;margin:24px 0;display:flex;justify-content:center;align-items:center;min-height:140px}.build-visual-bench{width:160px;height:120px;border-radius:12px;background:linear-gradient(180deg,#8d6e63,#6d4c41);border:4px solid #5d4037;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #37474f40}.build-visual-bench[data-stage=measure]{background:linear-gradient(180deg,#78909c,#607d8b);border-color:#546e7a}.build-visual-bench[data-stage=assemble],.build-visual-bench[data-stage=finish]{background:linear-gradient(180deg,#795548,#5d4037);border-color:#4e342e}.build-visual-bench[data-stage=done]{background:linear-gradient(180deg,#ffb74d,#ff9800);border-color:#f57c00;box-shadow:0 6px 20px #ff980059}.build-visual-empty{font-size:3.5rem;opacity:.9}.build-visual-parts{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;align-items:center;padding:8px}.build-visual-emoji{font-size:2rem;animation:build-pop .3s ease-out}@keyframes build-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.build-step{flex:1;display:flex;flex-direction:column;margin-top:8px}.build-step-label{font-size:1.35rem;font-weight:700;color:#37474f;margin:0 0 8px}.build-step-instruction{font-size:1.05rem;color:#546e7a;margin:0 0 20px;line-height:1.45}.build-step-done{margin-top:auto;padding-top:24px}.page--build-done{justify-content:center;text-align:center;padding:32px 20px}.build-done-content{margin-bottom:32px}.build-done-content .build-visual{margin:0 auto 24px}.build-done-title{font-size:1.75rem;font-weight:700;color:#37474f;margin:0 0 12px}.build-done-name{font-size:1.25rem;font-weight:600;color:#546e7a;margin:0 0 12px}.build-done-name .build-done-emoji{margin-right:8px}.build-done-message{font-size:1rem;color:#546e7a;max-width:320px;margin:0 auto}.build-done-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto}.page--hardware-shop{padding:20px;min-height:100%;background:linear-gradient(180deg,#eceff1,#cfd8dc)}.hardware-shop-header{margin-bottom:24px}.hardware-shop-header .page-title{margin:0}.page--repair-list{padding:20px;min-height:100%;background:linear-gradient(180deg,#eceff1,#cfd8dc)}.repair-list-header{margin-bottom:16px}.repair-list-header .page-title{margin:0;font-size:1.35rem}.repair-list-intro{color:#37474f;font-size:1rem;margin:0 0 24px;max-width:360px}.repair-list-grid{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.repair-list-card{display:flex;flex-direction:column;align-items:center;padding:24px 20px;border-radius:var(--radius-big);text-decoration:none;color:#37474f;background:var(--surface);box-shadow:0 4px 16px #37474f1f;border:3px solid #8d6e63;transition:transform .1s,box-shadow .2s}.repair-list-card:active,.repair-list-card:hover{transform:scale(1.01);box-shadow:0 6px 20px #37474f26}.repair-list-card-emoji{font-size:2.5rem;margin-bottom:8px;display:block}.repair-list-card-name{font-size:1.2rem;font-weight:700;margin-bottom:2px}.repair-list-card-desc{font-size:.9rem;color:#546e7a;margin-bottom:4px}.repair-list-card-steps{font-size:.85rem;color:var(--text-muted)}.page--repair{display:flex;flex-direction:column;min-height:100%;padding:20px;background:linear-gradient(180deg,#eceff1,#cfd8dc)}.repair-header{margin-bottom:16px}.repair-header .btn-back{margin-bottom:8px}.repair-task-name{font-size:1.25rem;font-weight:700;color:#37474f;margin:0 0 4px}.repair-progress{font-size:.95rem;color:#546e7a;margin:0}.repair-visual{flex-shrink:0;margin:24px 0;display:flex;justify-content:center;align-items:center;min-height:140px}.repair-visual-toolbox{width:160px;height:120px;border-radius:12px;background:linear-gradient(180deg,#8d6e63,#6d4c41);border:4px solid #5d4037;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #37474f40}.repair-visual-toolbox[data-stage=assemble],.repair-visual-toolbox[data-stage=finish]{background:linear-gradient(180deg,#78909c,#607d8b);border-color:#546e7a}.repair-visual-toolbox[data-stage=done]{background:linear-gradient(180deg,#81c784,#43a047);border-color:#2e7d32;box-shadow:0 6px 20px #43a04759}.repair-visual-empty{font-size:3.5rem;opacity:.9}.repair-visual-parts{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;align-items:center;padding:8px}.repair-visual-emoji{font-size:2rem;animation:build-pop .3s ease-out}.repair-step{flex:1;display:flex;flex-direction:column;margin-top:8px}.repair-step-label{font-size:1.35rem;font-weight:700;color:#37474f;margin:0 0 8px}.repair-step-instruction{font-size:1.05rem;color:#546e7a;margin:0 0 20px;line-height:1.45}.repair-step-done{margin-top:auto;padding-top:24px}.page--repair-done{justify-content:center;text-align:center;padding:32px 20px}.repair-done-content{margin-bottom:32px}.repair-done-content .repair-visual{margin:0 auto 24px}.repair-done-title{font-size:1.75rem;font-weight:700;color:#37474f;margin:0 0 12px}.repair-done-name{font-size:1.25rem;font-weight:600;color:#546e7a;margin:0 0 12px}.repair-done-name .repair-done-emoji{margin-right:8px}.repair-done-message{font-size:1rem;color:#546e7a;max-width:320px;margin:0 auto}.repair-done-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto}.page--paint{padding:20px;min-height:100%;background:linear-gradient(180deg,#f3e5f5,#e1bee7)}.paint-header{margin-bottom:16px}.paint-header .page-title{margin:0}.paint-prompt{font-size:1.1rem;color:#4a148c;margin:0 0 24px;font-weight:600}.paint-object-grid{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.paint-object-card{display:flex;flex-direction:column;align-items:center;padding:28px 20px;border-radius:var(--radius-big);font-family:inherit;font-size:1rem;color:#4a148c;background:var(--surface);border:3px solid #ce93d8;box-shadow:0 4px 16px #9c27b026;transition:transform .1s,box-shadow .2s;cursor:pointer}.paint-object-card:active,.paint-object-card:hover{transform:scale(1.02);box-shadow:0 6px 20px #9c27b033}.paint-object-emoji{font-size:3rem;margin-bottom:8px;display:block}.paint-object-name{font-size:1.25rem;font-weight:700}.paint-color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:280px;margin:0 auto 24px}.paint-color-swatch{aspect-ratio:1;border-radius:50%;border:4px solid rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s,box-shadow .2s;min-height:72px}.paint-color-swatch:hover,.paint-color-swatch:active{transform:scale(1.1);box-shadow:0 6px 20px #0003}.paint-color-emoji{font-size:1.75rem}.page--paint-done{justify-content:center;text-align:center;padding:32px 20px;background:linear-gradient(180deg,#f3e5f5,#e1bee7)}.paint-done-content{margin-bottom:32px}.paint-done-preview{width:120px;height:120px;border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;border:4px solid rgba(0,0,0,.15);box-shadow:0 8px 24px #00000026}.paint-done-emoji{font-size:4rem}.paint-done-title{font-size:1.75rem;font-weight:700;color:#4a148c;margin:0 0 12px}.paint-done-name{font-size:1.2rem;color:#6a1b9a;margin:0 0 24px}.paint-done-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto}.page--measure{padding:20px;min-height:100%;background:linear-gradient(180deg,#e8eaf6,#c5cae9)}.measure-header{margin-bottom:16px}.measure-header .page-title{margin:0}.measure-question{font-size:1.35rem;font-weight:700;color:#283593;margin:0 0 20px;text-align:center}.measure-ruler{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:16px;background:var(--surface);border-radius:var(--radius-big);border:3px solid #5c6bc0;max-width:360px;margin-left:auto;margin-right:auto}.measure-emoji{font-size:3rem;flex-shrink:0}.measure-ruler-blocks{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.measure-block{width:36px;height:36px;border-radius:6px;background:#7986cb;color:var(--surface);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:background .2s,transform .1s}.measure-block--selected{background:#3949ab;transform:scale(1.05)}.measure-block--correct{background:#43a047}.measure-prompt{font-size:1rem;color:#3949ab;margin:0 0 16px;font-weight:600}.measure-options{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:16px}.measure-option-btn{min-width:100px}.measure-option-btn--selected{border-color:#3949ab;background:#e8eaf6}.measure-option-btn--correct{border-color:#43a047;background:#e8f5e9;color:#2e7d32}.measure-option-btn--wrong{border-color:#e53935;background:#ffebee;color:#c62828}.measure-result{margin-top:24px;text-align:center}.measure-result-text{font-size:1.1rem;font-weight:600;color:#283593;margin:0 0 16px}.measure-done-actions{margin-top:24px}.measure-done-title{font-size:1.5rem;font-weight:700;color:#283593;margin:0 0 20px}.measure-done-actions .btn-large{margin-bottom:8px}.page--bake-list{padding:20px;min-height:100%;background:linear-gradient(180deg,#fff8e1,#ffecb3)}.bake-list-header{margin-bottom:12px}.bake-list-title{margin:0;font-size:1.4rem;font-weight:700;color:#5d4037}.bake-list-meta{margin:4px 0 0;font-size:.95rem;color:#8d6e63}.bake-list-header .page-title{margin:0;font-size:1.35rem}.bake-list-intro{color:#5d4037;font-size:1rem;margin:0 0 24px;max-width:360px}.bake-list-grid{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.bake-list-card{display:flex;flex-direction:column;align-items:flex-start;padding:20px;border-radius:var(--radius-big);text-decoration:none;color:#5d4037;background:var(--surface);box-shadow:0 4px 16px #5d40371a;border:2px solid #d7ccc8;transition:transform .15s ease,box-shadow .2s ease}.bake-list-card:active,.bake-list-card:hover{transform:scale(1.02);box-shadow:0 8px 24px #5d40372e}.bake-list-back{margin-top:24px}.bake-list-card-emoji{font-size:2.5rem;margin-bottom:8px;display:block}.bake-list-card-name{font-size:1.2rem;font-weight:700;margin-bottom:2px}.bake-list-card-desc{font-size:.9rem;color:#6d4c41;margin-bottom:4px}.bake-list-card-steps{font-size:.85rem;color:var(--text-muted)}.page--bake{display:flex;flex-direction:column;min-height:100%;padding:20px;background:linear-gradient(180deg,#fff8e1,#ffecb3)}.bake-header{margin-bottom:16px}.bake-header .btn-back{margin-bottom:8px}.bake-recipe-name{font-size:1.25rem;font-weight:700;color:#5d4037;margin:0 0 8px}.bake-progress-wrap{margin-top:4px}.bake-progress-text{font-size:.95rem;color:#6d4c41;margin:0;display:block}.bake-progress-dots{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.bake-progress-dot{width:10px;height:10px;border-radius:50%;background:#d7ccc8;transition:background .25s ease,transform .2s ease}.bake-progress-dot--done{background:#8d6e63}.bake-progress-dot--current{background:#5d4037;transform:scale(1.2);box-shadow:0 0 0 2px #fff8e1}.bake-progress{font-size:.95rem;color:#6d4c41;margin:0}.bake-build{flex-shrink:0;margin:24px 0;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:160px;gap:12px}.bake-build-scene{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.bake-build-scene--oven{padding:16px}.bake-oven-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;background:radial-gradient(circle,rgba(255,152,0,.25) 0%,rgba(255,87,34,.1) 40%,transparent 70%);animation:bake-oven-glow-pulse 1.5s ease-in-out infinite;pointer-events:none}@keyframes bake-oven-glow-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.bake-spoon{position:absolute;top:-8px;left:50%;margin-left:-24px;font-size:2.5rem;z-index:2;animation:bake-spoon-stir 2s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}@keyframes bake-spoon-stir{0%,to{transform:rotate(-25deg)}25%{transform:rotate(15deg)}50%{transform:rotate(-20deg)}75%{transform:rotate(10deg)}}.bake-build-next{display:flex;flex-direction:column;align-items:center;gap:4px;animation:bake-pulse 1.5s ease-in-out infinite}@keyframes bake-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.05)}}.bake-build-next-label{font-size:.85rem;font-weight:600;color:#8d6e63;text-transform:uppercase;letter-spacing:.05em}.bake-build-next-emoji{font-size:3rem;display:block;animation:bake-pulse 1.5s ease-in-out infinite}.bake-build-bowl{width:180px;height:150px;border-radius:50% 50% 48% 48%;background:linear-gradient(180deg,#efebe9,#d7ccc8);border:4px solid #bcaaa4;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 6px 16px #00000014,0 6px 20px #5d403740;transition:box-shadow .3s ease}.bake-build-bowl[data-stage=mix]{background:linear-gradient(180deg,#d7ccc8,#bcaaa4);animation:bake-bowl-wobble 2.5s ease-in-out infinite}@keyframes bake-bowl-wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}.bake-build-bowl[data-stage=oven],.bake-build-bowl[data-stage=decorate]{background:linear-gradient(180deg,#8d6e63,#6d4c41);border-color:#5d4037}.bake-build-bowl[data-stage=oven]{box-shadow:inset 0 6px 16px #00000026,0 6px 20px #5d40374d,0 0 30px #ff980033;animation:bake-oven-shimmer 2s ease-in-out infinite}@keyframes bake-oven-shimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}.bake-build-bowl[data-stage=decorate]{animation:bake-decorate-sparkle 1.5s ease-in-out infinite}@keyframes bake-decorate-sparkle{0%,to{box-shadow:inset 0 6px 16px #00000014,0 6px 20px #5d403740}50%{box-shadow:inset 0 6px 16px #00000014,0 6px 24px #8d6e6366,0 0 20px #ffc10726}}.bake-build-bowl[data-stage=done]{background:linear-gradient(180deg,#ffcc80,#ff9800);border-color:#e65100;box-shadow:0 6px 20px #e651004d}.bake-build-empty{font-size:3.5rem;opacity:.9}.bake-build-ingredients{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;align-items:center;padding:8px}.bake-build-ingredients--mixing{animation:bake-ingredients-mix 2s ease-in-out infinite}@keyframes bake-ingredients-mix{0%,to{transform:rotate(0) scale(1)}33%{transform:rotate(-3deg) scale(1.02)}66%{transform:rotate(3deg) scale(1.02)}}.bake-build-ingredients--decorate{animation:bake-decorate-bounce 1.2s ease-in-out infinite}@keyframes bake-decorate-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.bake-build-emoji{font-size:2rem;animation:bake-pop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes bake-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.bake-step{flex:1;display:flex;flex-direction:column;margin-top:8px}.bake-step-label{font-size:1.35rem;font-weight:700;color:#5d4037;margin:0 0 8px}.bake-step-instruction{font-size:1.05rem;color:#6d4c41;margin:0 0 20px;line-height:1.45}.bake-step-done{margin-top:auto;padding-top:24px;display:inline-flex;align-items:center;justify-content:center;gap:10px;animation:bake-btn-idle 4s ease-in-out infinite}@keyframes bake-btn-idle{0%,95%,to{transform:scale(1)}97%{transform:scale(1.02)}99%{transform:scale(1)}}.bake-step-done:active{animation:none;transform:scale(.97)}.bake-step-done-icon{font-size:1.5rem}.page--bake-done{justify-content:center;text-align:center;padding:32px 20px}.bake-done-content{margin-bottom:32px}.bake-done-treat{margin-bottom:16px}.bake-done-treat-emoji{font-size:5rem;display:inline-block;animation:bake-done-pop .5s cubic-bezier(.34,1.56,.64,1) forwards,bake-done-float 2s ease-in-out .6s infinite;filter:drop-shadow(0 4px 12px rgba(93,64,55,.3))}@keyframes bake-done-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes bake-done-float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.05)}}.bake-done-content .bake-build{margin:0 auto 24px}.bake-done-title{font-size:1.85rem;font-weight:700;color:#5d4037;margin:0 0 12px}.bake-done-name{font-size:1.25rem;font-weight:600;color:#6d4c41;margin:0 0 12px}.bake-done-name .bake-done-emoji{margin-right:8px}.bake-done-message{font-size:1rem;color:#6d4c41;max-width:320px;margin:0 auto}.bake-done-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto}.page--bakery-shop{padding:20px;min-height:100%;background:linear-gradient(180deg,#fff8e1,#ffecb3)}.bakery-shop-header{margin-bottom:24px}.bakery-shop-header .page-title{margin:0}
