:root{--color-primary: #1a3a2a;--color-primary-light: #2d5a3f;--color-primary-pale: #e8f0ec;--color-accent: #c8944a;--color-accent-light: #f5e6d0;--color-bg: #f6f3ee;--color-surface: #ffffff;--color-surface-warm: #fdfcfa;--color-text: #1a1a18;--color-text-secondary: #6b6960;--color-text-muted: #9c9889;--color-border: #e8e4dd;--color-border-light: #f0ece6;--color-success: #3a7d5c;--color-success-bg: #ecf5f0;--color-danger: #b5403a;--color-danger-bg: #fdf0ef;--color-info: #3a6b8c;--color-info-bg: #eaf1f6;--font-display: "Fraunces", "Georgia", serif;--font-body: "DM Sans", system-ui, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(26, 26, 24, .04);--shadow-md: 0 2px 8px rgba(26, 26, 24, .06), 0 1px 2px rgba(26, 26, 24, .04);--shadow-lg: 0 8px 24px rgba(26, 26, 24, .08), 0 2px 6px rgba(26, 26, 24, .04);--shadow-elevated: 0 12px 40px rgba(26, 26, 24, .12), 0 4px 12px rgba(26, 26, 24, .06)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;min-height:100dvh;background:var(--color-bg);display:flex;flex-direction:column}.navbar{background:var(--color-primary);color:#fff;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:54px;position:sticky;top:0;z-index:50;flex-shrink:0}.logo{font-family:var(--font-display);font-size:1.35rem;font-weight:500;margin:0;letter-spacing:-.02em;font-optical-sizing:auto}.nav-right{display:flex;align-items:center;gap:.5rem}.nav-store-select{padding:.3rem .5rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.2);font-size:.78rem;background:#ffffff1a;color:#ffffffe6;max-width:120px;font-family:var(--font-body);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nav-store-select option{color:var(--color-text);background:var(--color-surface)}.nav-logout{padding:.3rem .65rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.15);font-size:.78rem;background:#ffffff14;color:#ffffffbf;cursor:pointer;white-space:nowrap;font-family:var(--font-body);transition:all .15s ease}.nav-logout:hover{background:#ffffff26;color:#fff}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);display:flex;box-shadow:0 -1px 8px #1a1a1814;z-index:50;padding-bottom:env(safe-area-inset-bottom,0);border-top:1px solid var(--color-border-light)}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .25rem;font-size:.62rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;gap:.2rem;transition:color .2s ease;min-height:52px;letter-spacing:.01em}.bottom-nav a.active{color:var(--color-primary);font-weight:600}.bottom-nav .nav-icon{font-size:1.2rem;line-height:1}.main-content{flex:1;max-width:900px;width:100%;margin:0 auto;padding:1.25rem 1rem;padding-bottom:calc(60px + env(safe-area-inset-bottom,0) + 1.25rem)}h2{font-family:var(--font-display);color:var(--color-text);margin:0 0 .85rem;font-size:1.35rem;font-weight:500;letter-spacing:-.02em}h3{font-family:var(--font-display);margin:0 0 .5rem;font-size:1.05rem;font-weight:500;letter-spacing:-.01em}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:1.1rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}button{cursor:pointer;border:none;padding:.6rem 1.1rem;border-radius:var(--radius-md);font-size:.88rem;font-family:var(--font-body);font-weight:500;transition:all .2s ease;touch-action:manipulation}button:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-light);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-primary-pale);color:var(--color-primary)}.btn-secondary:hover{background:#dce8e1}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#9e3732}.btn-small{padding:.35rem .65rem;font-size:.8rem}input,textarea,select{width:100%;padding:.65rem .85rem;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.95rem;font-family:var(--font-body);box-sizing:border-box;appearance:none;-webkit-appearance:none;background:var(--color-surface);color:var(--color-text);transition:border-color .2s ease,box-shadow .2s ease}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b6960' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2.2rem}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a3a2a1a}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}.input-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.85rem}.input-group input{flex:1;min-width:0}.filter-row{display:flex;gap:.5rem;margin-bottom:.5rem}.filter-row select{flex:1;font-size:.85rem;padding:.5rem .65rem}.item-row{display:flex;align-items:center;gap:.6rem;padding:.8rem 0;border-bottom:1px solid var(--color-border-light);min-height:48px;transition:background .15s ease}.item-row:last-child{border-bottom:none}.item-row.checked .item-name{text-decoration:line-through;color:var(--color-text-muted)}.item-row input[type=checkbox]{width:20px;height:20px;flex-shrink:0;accent-color:var(--color-primary);border-radius:4px}.item-name{flex:1;min-width:0;word-break:break-word;font-size:.93rem}.item-meta{color:var(--color-text-muted);font-size:.78rem}.price-tag{color:var(--color-success);font-weight:600;font-size:.83rem;white-space:nowrap}.store-tag{background:var(--color-info-bg);color:var(--color-info);padding:.18rem .45rem;border-radius:var(--radius-sm);font-size:.68rem;font-weight:500;white-space:nowrap;letter-spacing:.01em}.list-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:.85rem;flex-wrap:wrap;gap:.5rem}.list-actions-buttons{display:flex;gap:.4rem;flex-wrap:wrap}.week-grid{display:flex;flex-direction:column;gap:.5rem}.day-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:.85rem 1rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);display:flex;align-items:flex-start;gap:.85rem;transition:box-shadow .2s ease}.day-card:hover{box-shadow:var(--shadow-md)}.day-card h4{margin:0;font-family:var(--font-display);color:var(--color-primary);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;min-width:50px;padding-top:.15rem}.day-card-content{flex:1}.day-card.today{border-left:3px solid var(--color-accent);background:var(--color-surface-warm)}.search-results{max-height:300px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:.5rem;background:var(--color-surface)}.search-result-item{padding:.7rem .85rem;border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;gap:.65rem;cursor:pointer;min-height:48px;transition:background .15s ease}.search-result-item:hover{background:var(--color-primary-pale)}.search-result-item:active{background:#dce8e1}.search-result-item img{width:38px;height:38px;object-fit:contain;flex-shrink:0;border-radius:var(--radius-sm);background:var(--color-bg)}.recipe-card{display:flex;gap:.85rem;cursor:pointer;align-items:center}.recipe-card img{width:64px;height:64px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.recipe-card h3{margin:0 0 .15rem;font-size:.98rem}.recipe-card p{margin:0;color:var(--color-text-secondary);font-size:.83rem}.modal-overlay{position:fixed;inset:0;background:#1a1a1873;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:overlayFadeIn .2s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:1.25rem;width:100%;max-height:85vh;max-height:85dvh;overflow-y:auto;box-shadow:var(--shadow-elevated);animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-content:before{content:"";display:block;width:36px;height:4px;background:var(--color-border);border-radius:2px;margin:0 auto 1rem}.tab-bar{display:flex;gap:0;margin-bottom:1rem;border-bottom:1.5px solid var(--color-border-light);overflow-x:auto;-webkit-overflow-scrolling:touch}.tab,.tab-active{background:none;border:none;padding:.65rem .85rem;font-size:.85rem;font-family:var(--font-body);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;color:var(--color-text-muted);border-radius:0;white-space:nowrap;flex-shrink:0;font-weight:500;transition:color .15s ease}.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tab:hover{color:var(--color-text)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:.4rem}.spinner-dark{border-color:#1a3a2a1a;border-top-color:var(--color-primary)}.spinner-large{width:32px;height:32px;border-width:3px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-border-light) 25%,var(--color-border) 50%,var(--color-border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:4px;height:1rem;margin-bottom:.5rem}.skeleton-line{height:.9rem;width:100%}.skeleton-line-short{height:.9rem;width:60%}.card-loading{position:relative;pointer-events:none}.card-loading:after{content:"";position:absolute;inset:0;background:#fff9;border-radius:var(--radius-md)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}.btn-loading{animation:pulse 1.2s ease-in-out infinite;pointer-events:none}.progress-bar{width:100%;height:3px;background:var(--color-border-light);border-radius:2px;overflow:hidden;margin:.5rem 0}.progress-bar-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(300%)}}.progress-bar-indeterminate .progress-bar-fill{width:33%;animation:progress-indeterminate 1.2s ease-in-out infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .35s ease-out}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table-wrap table{width:100%;border-collapse:collapse;white-space:nowrap;font-size:.88rem}.admin-table-wrap th{text-align:left;padding:.6rem .5rem;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);border-bottom:1.5px solid var(--color-border)}.admin-table-wrap td{padding:.55rem .5rem;border-bottom:1px solid var(--color-border-light)}@media(min-width:769px){.navbar{padding:0 2rem;height:60px}.logo{font-size:1.5rem}.bottom-nav{display:none}.desktop-nav{display:flex!important;gap:.25rem;align-items:center;flex:1;margin-left:2rem}.desktop-nav a{color:#ffffffb3;text-decoration:none;padding:.45rem .85rem;border-radius:var(--radius-md);transition:all .2s ease;white-space:nowrap;font-size:.88rem;font-weight:500}.desktop-nav a:hover{background:#ffffff1a;color:#ffffffe6}.desktop-nav a.active{background:#ffffff26;color:#fff;font-weight:600}.main-content{padding:1.75rem 2rem 2rem}h2{font-size:1.6rem}.card{padding:1.5rem;border-radius:var(--radius-lg)}.input-group{flex-direction:row}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem}.day-card{flex-direction:column;min-height:140px;padding:1rem}.day-card h4{min-width:unset}.modal-overlay{align-items:center;padding:2rem}.modal-content{border-radius:var(--radius-xl);max-width:550px;animation:modalFadeIn .25s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content:before{display:none}}.desktop-nav{display:none}.background-tasks-bar{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px) + .5rem);right:.75rem;left:.75rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem}@media(min-width:769px){.background-tasks-bar{bottom:1rem;right:1rem;left:auto;max-width:350px}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}
