:root{--color-bg: #F7F5F2;--color-surface: #FFFFFF;--color-surface-alt: #EFEDE9;--color-header: #1C1917;--color-header-text: #F7F5F2;--color-text: #1C1917;--color-text-muted: #78716C;--color-text-faint: #A8A29E;--color-accent: #C2410C;--color-accent-light: #FED7AA;--color-weekend: #292524;--color-weekend-bg: #FAFAF9;--color-border: #E7E5E4;--color-tab-active: #1C1917;--color-tab-inactive: #A8A29E;--font-display: "Fraunces", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-pill: 100px;--shadow-sm: 0 1px 3px rgba(28,25,23,.08), 0 1px 2px rgba(28,25,23,.04);--shadow-md: 0 4px 16px rgba(28,25,23,.1), 0 1px 4px rgba(28,25,23,.06);--shadow-sheet: 0 -8px 40px rgba(28,25,23,.14);--tab-bar-height: 68px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior:none}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}input,textarea{font-family:var(--font-body)}.app-shell{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;position:relative;background:var(--color-bg)}.app-header{background:var(--color-header);color:var(--color-header-text);padding:16px 20px 14px;padding-top:max(16px,env(safe-area-inset-top,16px));display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:10}.header-title{font-family:var(--font-display);font-size:22px;font-weight:400;font-style:italic;letter-spacing:-.3px;color:var(--color-header-text)}.header-subtitle{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:#a8a29e;margin-top:1px}.header-user{display:flex;align-items:center;gap:8px}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-accent);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s;border:2px solid rgba(255,255,255,.15)}.user-avatar:hover{opacity:.85}.content-area{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding-bottom:calc(var(--tab-bar-height) + var(--safe-bottom) + 16px)}.tab-bar{position:absolute;bottom:0;left:0;right:0;height:calc(var(--tab-bar-height) + var(--safe-bottom));background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:flex-start;padding-top:8px;padding-bottom:var(--safe-bottom);z-index:20;box-shadow:0 -1px #0000000a}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;color:var(--color-tab-inactive);transition:color .18s;background:none;border:none;cursor:pointer}.tab-btn.active{color:var(--color-tab-active)}.tab-icon{font-size:22px;line-height:1}.tab-label{font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.tab-dot{width:4px;height:4px;border-radius:50%;background:var(--color-accent);opacity:0;transition:opacity .18s}.tab-btn.active .tab-dot{opacity:1}.login-screen{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px;background:var(--color-header);gap:0}.login-logo{font-family:var(--font-display);font-size:42px;font-weight:300;font-style:italic;color:var(--color-bg);text-align:center;line-height:1.1;margin-bottom:6px}.login-tagline{font-size:13px;font-weight:400;color:#78716c;text-align:center;margin-bottom:48px;letter-spacing:.02em}.login-card{width:100%;max-width:340px;background:var(--color-bg);border-radius:var(--radius-lg);padding:28px 24px 24px}.login-card h2{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--color-text);margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-group label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.form-input{width:100%;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:15px;background:var(--color-surface);color:var(--color-text);transition:border-color .15s;outline:none}.form-input:focus{border-color:var(--color-accent)}.btn-primary{width:100%;padding:13px;background:var(--color-header);color:var(--color-bg);border-radius:var(--radius-sm);font-size:15px;font-weight:500;letter-spacing:.01em;margin-top:6px;transition:opacity .15s}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.login-error{font-size:13px;color:var(--color-accent);margin-top:10px;text-align:center}.tab-placeholder{padding:32px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--color-text-muted);text-align:center;min-height:60vh}.tab-placeholder .placeholder-icon{font-size:48px;opacity:.5}.tab-placeholder h2{font-family:var(--font-display);font-size:24px;font-weight:400;font-style:italic;color:var(--color-text)}.tab-placeholder p{font-size:14px;color:var(--color-text-muted);max-width:260px}.user-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#1c191766;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center}.user-menu-sheet{width:100%;max-width:480px;background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:20px 20px calc(24px + var(--safe-bottom));box-shadow:var(--shadow-sheet);animation:slideUp .22s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.user-menu-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--color-border)}.user-menu-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-accent);color:#fff;font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:center}.user-menu-info strong{display:block;font-size:15px;font-weight:600;color:var(--color-text)}.user-menu-info span{font-size:13px;color:var(--color-text-muted)}.btn-logout{width:100%;padding:13px;border-radius:var(--radius-sm);font-size:15px;font-weight:500;background:#fef2f2;color:#dc2626;transition:opacity .15s}.btn-logout:hover{opacity:.85}.btn-cancel{width:100%;padding:13px;border-radius:var(--radius-sm);font-size:15px;font-weight:500;background:var(--color-surface-alt);color:var(--color-text-muted);margin-top:8px;transition:opacity .15s}.btn-cancel:hover{opacity:.85}.loading-screen{height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-header)}.spinner{width:28px;height:28px;border:2.5px solid rgba(247,245,242,.2);border-top-color:var(--color-bg);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.planner{padding-bottom:8px}.week-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 10px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:5}.week-nav-btn{width:36px;height:36px;border-radius:50%;background:var(--color-surface-alt);color:var(--color-text);font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.week-nav-btn:active{background:var(--color-border)}.week-nav-center{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.week-nav-label{font-size:14px;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.week-today-pill{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-accent);background:var(--color-accent-light);padding:2px 10px;border-radius:var(--radius-pill)}.planner-loading{display:flex;align-items:center;justify-content:center;padding:60px 0}.spinner-dark{width:24px;height:24px;border:2.5px solid var(--color-border);border-top-color:var(--color-text-muted);border-radius:50%;animation:spin .7s linear infinite}.planner-error{margin:16px;padding:14px 16px;background:#fef2f2;color:#dc2626;border-radius:var(--radius-md);font-size:14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.planner-error button{font-size:13px;font-weight:600;color:#dc2626;text-decoration:underline}.planner-days{display:flex;flex-direction:column;gap:0}.day-row{border-bottom:1px solid var(--color-border);background:var(--color-bg)}.day-row--weekend{background:#f0edea}.day-header{display:flex;align-items:baseline;gap:6px;padding:12px 16px 6px}.day-name{font-family:var(--font-display);font-size:17px;font-weight:500;font-style:italic;color:var(--color-text);letter-spacing:-.02em}.day-date{font-size:12px;font-weight:400;color:var(--color-text-muted)}.day-row--weekend .day-name{color:var(--color-accent)}.meal-slots{display:flex;flex-direction:column;padding:0 12px 10px;gap:4px}.meal-slot{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--color-surface);border:1.5px solid var(--color-border);text-align:left;transition:border-color .15s,background .15s;cursor:pointer}.meal-slot:active{background:var(--color-surface-alt)}.meal-slot--filled{border-color:transparent;background:var(--color-surface);box-shadow:var(--shadow-sm)}.day-row--weekend .meal-slot{background:#ffffffb3}.day-row--weekend .meal-slot--filled{background:var(--color-surface)}.meal-slot-inner{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.meal-type-label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-faint)}.meal-slot--filled .meal-type-label{color:var(--color-accent)}.meal-value{font-size:13.5px;font-weight:400;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.35}.meal-value--empty{color:var(--color-text-faint);font-style:italic}.meal-meta{font-size:11px;color:var(--color-text-faint);margin-top:1px}.meal-slot-chevron{font-size:18px;color:var(--color-text-faint);flex-shrink:0;margin-right:-2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#1c191780;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center}.modal-sheet{width:100%;max-width:480px;background:var(--color-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding-bottom:max(24px,env(safe-area-inset-bottom,24px));max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sheet);animation:slideUp .24s cubic-bezier(.32,.72,0,1)}.modal-handle{width:36px;height:4px;background:var(--color-border);border-radius:var(--radius-pill);margin:12px auto 0}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--color-border)}.modal-title{font-family:var(--font-display);font-size:20px;font-weight:500;font-style:italic;color:var(--color-text);letter-spacing:-.02em}.modal-subtitle{font-size:13px;color:var(--color-text-muted);margin-top:2px}.modal-close{width:30px;height:30px;border-radius:50%;background:var(--color-surface-alt);color:var(--color-text-muted);font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.modal-section{padding:14px 20px 0}.modal-section--library{padding-bottom:4px}.modal-section-label{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:8px}.modal-textarea{width:100%;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:15px;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text);resize:none;outline:none;transition:border-color .15s;line-height:1.5}.modal-textarea:focus{border-color:var(--color-accent)}.library-list{display:flex;flex-direction:column;gap:3px;max-height:280px;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface)}.library-item{width:100%;padding:11px 14px;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:8px;background:none;border-bottom:1px solid var(--color-border);transition:background .12s}.library-item:last-child{border-bottom:none}.library-item:active,.library-item--selected{background:var(--color-accent-light)}.library-item-text{font-size:14px;color:var(--color-text);line-height:1.35;flex:1;min-width:0}.library-item--selected .library-item-text{font-weight:600;color:var(--color-accent)}.library-item-check{font-size:14px;color:var(--color-accent);font-weight:700;flex-shrink:0}.modal-actions{padding:16px 20px 0}.btn-full{display:block;width:100%}.btn-ghost{padding:13px;border-radius:var(--radius-sm);font-size:15px;font-weight:500;background:var(--color-surface-alt);color:var(--color-text-muted);margin-top:8px;transition:opacity .15s;font-family:var(--font-body);cursor:pointer;border:none}.btn-ghost:hover{opacity:.85}.add-to-lib{padding:28px 24px 8px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}.add-to-lib-icon{font-size:36px;margin-bottom:4px}.add-to-lib-title{font-family:var(--font-display);font-size:20px;font-weight:500;font-style:italic;color:var(--color-text)}.add-to-lib-meal{font-size:14px;font-weight:600;color:var(--color-accent);margin:2px 0 4px}.add-to-lib-desc{font-size:13.5px;color:var(--color-text-muted);max-width:280px;line-height:1.5;margin-bottom:8px}.add-to-lib .btn-primary{margin-top:4px}.library{padding-bottom:8px}.library-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 0;gap:12px}.library-seed-msg{font-size:13px;color:var(--color-text-muted)}.library-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 10px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:5}.library-count{font-size:13px;color:var(--color-text-muted);font-weight:500}.library-import-btn{font-size:13px;font-weight:600;color:var(--color-accent);padding:6px 14px;border-radius:var(--radius-pill);background:var(--color-accent-light);transition:opacity .15s}.library-import-btn:hover{opacity:.85}.library-section{border-bottom:1px solid var(--color-border)}.library-section-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 8px}.library-section-title-row{display:flex;align-items:center;gap:8px}.library-section-title{font-family:var(--font-display);font-size:18px;font-weight:500;font-style:italic;color:var(--color-text);letter-spacing:-.02em}.library-section-count{font-size:11px;font-weight:600;color:var(--color-text-faint);background:var(--color-surface-alt);border-radius:var(--radius-pill);padding:2px 8px;min-width:22px;text-align:center}.library-add-btn{width:32px;height:32px;border-radius:50%;background:var(--color-header);color:var(--color-bg);font-size:22px;font-weight:300;display:flex;align-items:center;justify-content:center;line-height:1;flex-shrink:0;transition:opacity .15s}.library-add-btn:hover{opacity:.85}.library-empty{padding:4px 12px 12px}.library-empty-add{font-size:13.5px;color:var(--color-text-faint);font-style:italic;padding:12px 14px;border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);width:100%;text-align:left;transition:border-color .15s,color .15s}.library-empty-add:active{border-color:var(--color-accent);color:var(--color-accent)}.library-meal-list{list-style:none;padding:0 12px 12px;display:flex;flex-direction:column;gap:3px}.library-meal-item{display:flex;align-items:stretch;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border);overflow:hidden}.library-meal-name{flex:1;min-width:0;padding:12px 14px;text-align:left;font-size:14px;color:var(--color-text);line-height:1.4;transition:background .12s}.library-meal-name:active{background:var(--color-surface-alt)}.library-meal-delete{padding:12px 14px;font-size:13px;color:var(--color-text-faint);border-left:1px solid var(--color-border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:color .12s,background .12s;min-width:44px}.library-meal-delete:active{color:#dc2626;background:#fef2f2}.type-selector{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.type-pill{padding:7px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:500;background:var(--color-surface-alt);color:var(--color-text-muted);border:1.5px solid transparent;transition:background .12s,color .12s,border-color .12s}.type-pill--active{background:var(--color-accent-light);color:var(--color-accent);border-color:var(--color-accent);font-weight:600}.modal-field-error{font-size:13px;color:#dc2626;margin-top:8px}.btn-danger{display:block;width:100%;padding:13px;border-radius:var(--radius-sm);font-size:15px;font-weight:500;background:#fef2f2;color:#dc2626;transition:opacity .15s;font-family:var(--font-body);cursor:pointer;border:none}.btn-danger:hover{opacity:.85}.delete-confirm-meal{font-size:15px;font-weight:600;color:var(--color-text);margin-bottom:6px}.delete-confirm-desc{font-size:13.5px;color:var(--color-text-muted);line-height:1.5}.modal-sheet--tall{max-height:95vh}.import-tabs{display:flex;background:var(--color-surface-alt);border-radius:var(--radius-sm);padding:3px}.import-tab{flex:1;padding:8px;font-size:13px;font-weight:500;border-radius:6px;color:var(--color-text-muted);transition:background .15s,color .15s}.import-tab--active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.import-textarea{height:160px;resize:none;font-size:13px;font-family:monospace}.import-file-hidden{display:none}.import-file-loaded{font-size:13px;color:var(--color-text-muted);margin-top:10px;text-align:center}.import-preview-list{list-style:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);overflow:hidden;margin-top:8px;margin-bottom:4px}.import-preview-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--color-border);font-size:13px}.import-preview-item:last-child{border-bottom:none}.import-preview-type{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-accent);flex-shrink:0;min-width:62px}.import-preview-value{color:var(--color-text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.import-preview-more{padding:8px 12px;font-size:13px;color:var(--color-text-faint);font-style:italic}.import-errors{margin-top:10px}.import-errors-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#dc2626;margin-bottom:6px}.import-error-list{list-style:none}.import-error-item{font-size:12px;color:#dc2626;padding:2px 0;line-height:1.4}.shopping{padding-bottom:8px}.shopping-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 0;gap:12px}.shopping-loading-msg{font-size:14px;color:var(--color-text-muted)}.shopping-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:52px 24px;gap:6px}.shopping-empty-icon{font-size:42px;margin-bottom:6px}.shopping-empty-title{font-family:var(--font-display);font-size:20px;font-weight:500;font-style:italic;color:var(--color-text);letter-spacing:-.02em}.shopping-empty-desc{font-size:14px;color:var(--color-text-muted);line-height:1.55;max-width:280px;margin-top:2px}.shopping-generate-btn{margin-top:18px;padding:13px 32px;background:var(--color-header);color:var(--color-header-text);border-radius:var(--radius-pill);font-size:15px;font-weight:600;font-family:var(--font-body);transition:opacity .15s}.shopping-generate-btn:hover{opacity:.88}.shopping-generate-btn:active{opacity:.78}.shopping-header-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.shopping-progress{font-size:13px;font-weight:500;color:var(--color-text-muted)}.shopping-regen-btn{font-size:13px;font-weight:600;color:var(--color-accent);background:var(--color-accent-light);padding:6px 14px;border-radius:var(--radius-pill);transition:opacity .15s}.shopping-regen-btn:hover{opacity:.85}.shopping-regen-btn:active{opacity:.72}.shopping-section{border-bottom:1px solid var(--color-border)}.shopping-section-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px 6px}.shopping-section-title{font-family:var(--font-display);font-size:17px;font-weight:500;font-style:italic;color:var(--color-text);letter-spacing:-.02em}.shopping-section-count{font-size:11px;font-weight:600;color:var(--color-text-faint);background:var(--color-surface-alt);border-radius:var(--radius-pill);padding:2px 8px;min-width:22px;text-align:center}.shopping-item-list{list-style:none;padding:0 12px 10px;display:flex;flex-direction:column;gap:3px}.shopping-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-align:left;cursor:pointer;transition:opacity .15s}.shopping-item:active{opacity:.7}.shopping-item--done{opacity:.42}.shopping-item--done .shopping-item-text{text-decoration:line-through;color:var(--color-text-muted)}.shopping-check{width:22px;height:22px;border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:transparent;transition:background .15s,border-color .15s,color .15s}.shopping-check--done{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.shopping-item-text{font-size:14px;color:var(--color-text);flex:1;min-width:0;line-height:1.4}.shopping-section--extras{border-bottom:none}.shopping-extra-row{display:flex;align-items:stretch}.shopping-extra-row .shopping-item{flex:1;border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.shopping-extra-remove{padding:0 15px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:20px;line-height:1;color:var(--color-text-faint);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .12s,background .12s}.shopping-extra-remove:active{color:#dc2626;background:#fef2f2}.shopping-add-extra{display:flex;gap:8px;padding:8px 12px 12px}.shopping-extra-input{flex:1;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text);outline:none;transition:border-color .15s;-webkit-appearance:none}.shopping-extra-input:focus{border-color:var(--color-accent)}.shopping-extra-input::placeholder{color:var(--color-text-faint)}.shopping-extra-add-btn{padding:12px 18px;background:var(--color-header);color:var(--color-header-text);border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:var(--font-body);flex-shrink:0;transition:opacity .15s;cursor:pointer}.shopping-extra-add-btn:disabled{opacity:.32;cursor:default}.shopping-extra-add-btn:not(:disabled):active{opacity:.78}
