:root{--color-primary: #C4613A;--color-primary-soft: #E08263;--color-secondary: #6B8F71;--color-accent: #E8A93A;--color-bg: #FDF8F3;--color-surface: #FFFFFF;--color-text: #2C1810;--color-text-soft: #6B5A4F;--color-line: #E8DCCB;--color-success: #6B8F71;--color-danger: #B8492C;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 22px;--shadow-soft: 0 2px 8px rgba(60, 30, 15, .06);--shadow-card: 0 4px 16px rgba(60, 30, 15, .08);--tap: 48px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--color-bg);color:var(--color-text);font-family:Nunito,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:16px;line-height:1.4;-webkit-font-smoothing:antialiased}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer;color:inherit}input,textarea,select{font-family:inherit;font-size:16px;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);padding:12px 14px;outline:none;width:100%}input:focus,textarea:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #c4613a26}h1,h2,h3{margin:0;font-weight:700}.app{min-height:100%;display:flex;flex-direction:column;max-width:720px;margin:0 auto;background:var(--color-bg);position:relative}.app-header{padding:18px 20px 12px;display:flex;align-items:center;justify-content:space-between}.app-header h1{font-size:26px;color:var(--color-primary);letter-spacing:-.5px}.app-header .subtitle{font-size:13px;color:var(--color-text-soft);margin-top:2px}.page{flex:1;padding:0 16px 120px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:space-around;background:var(--color-surface);border-top:1px solid var(--color-line);box-shadow:0 -2px 12px #3c1e0f0d;padding-bottom:var(--safe-bottom);z-index:50}.bottom-nav .container{display:flex;justify-content:space-around;width:100%;max-width:720px;margin:0 auto}.bottom-nav button{flex:1;min-height:64px;padding:8px 4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--color-text-soft);font-size:12px;font-weight:600}.bottom-nav button.active{color:var(--color-primary)}.bottom-nav .icon{font-size:22px;line-height:1}.fab{position:fixed;right:22px;bottom:calc(82px + var(--safe-bottom));width:60px;height:60px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:32px;font-weight:600;box-shadow:0 6px 18px #c4613a59;display:flex;align-items:center;justify-content:center;z-index:40}.fab:active{transform:scale(.96)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-soft)}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-soft);margin:18px 4px 10px}.item-row{display:flex;align-items:center;gap:14px;background:var(--color-surface);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:8px;min-height:56px}.item-row.completed .item-name{text-decoration:line-through;color:var(--color-text-soft)}.checkbox{width:28px;height:28px;flex-shrink:0;border-radius:8px;border:2px solid var(--color-line);display:flex;align-items:center;justify-content:center;background:var(--color-surface)}.checkbox.checked{background:var(--color-secondary);border-color:var(--color-secondary);color:#fff}.tap-target{display:flex;align-items:center;gap:14px;flex:1;min-height:48px;padding:4px 0}.item-name{font-weight:600;font-size:16px}.item-meta{font-size:13px;color:var(--color-text-soft);margin-top:2px}.btn{min-height:48px;padding:0 18px;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:active{transform:scale(.97)}.btn.btn-soft{background:#c4613a1a;color:var(--color-primary)}.btn.btn-secondary{background:var(--color-secondary)}.btn.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-line)}.btn.btn-danger{background:var(--color-danger)}.btn.full{width:100%}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c181066;z-index:100;display:flex;align-items:flex-end;justify-content:center}.sheet{background:var(--color-surface);border-radius:24px 24px 0 0;width:100%;max-width:720px;padding:20px 18px calc(20px + var(--safe-bottom));max-height:85vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet h2{font-size:20px;margin-bottom:14px}.field{margin-bottom:12px}.field label{display:block;font-weight:600;font-size:13px;margin-bottom:6px;color:var(--color-text-soft)}.row{display:flex;gap:10px}.row>*{flex:1}.badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:3px 8px;border-radius:999px;background:#6b8f7126;color:var(--color-secondary)}.badge.amber{background:#e8a93a2e;color:#9c7220}.badge.terra{background:#c4613a26;color:var(--color-primary)}.empty{text-align:center;padding:40px 20px;color:var(--color-text-soft)}.empty .emoji{font-size:44px;margin-bottom:12px}.pattern-card{display:flex;gap:12px;padding:14px;border-radius:var(--radius-md);background:linear-gradient(135deg,#e8a93a2e,#e8a93a14);margin-bottom:8px;align-items:center}.pattern-card .emoji{font-size:24px}.pattern-card .text{flex:1;font-size:14px}.shop-mode{background:var(--color-bg);min-height:100vh;padding:0 0 var(--safe-bottom)}.shop-header{position:sticky;top:0;background:var(--color-bg);padding:14px 16px 10px;z-index:10}.shop-header .row{align-items:center;justify-content:space-between}.shop-header h2{font-size:18px}.progress-bar{height:6px;background:var(--color-line);border-radius:999px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:var(--color-secondary);transition:width .25s ease}.shop-cat-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-soft);padding:14px 18px 6px;background:var(--color-bg);position:sticky;top:70px;z-index:5}.shop-row{display:flex;align-items:center;gap:16px;min-height:72px;padding:14px 18px;border-bottom:1px solid var(--color-line);background:var(--color-surface)}.shop-row.done{background:transparent;color:var(--color-text-soft)}.shop-row.done .shop-name{text-decoration:line-through}.shop-row .checkbox{width:32px;height:32px}.shop-name{font-size:18px;font-weight:700}.shop-meta{font-size:14px;color:var(--color-text-soft);margin-top:2px}.exit-shop{background:transparent;color:var(--color-text-soft);font-weight:600;padding:8px 14px;border-radius:999px;min-height:44px}.cat-icon{width:36px;height:36px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:#c4613a1a}.sub-tabs{display:flex;gap:6px;padding:0 16px 8px;overflow-x:auto;scrollbar-width:none}.sub-tabs::-webkit-scrollbar{display:none}.sub-tab{flex-shrink:0;padding:8px 14px;border-radius:999px;background:var(--color-surface);border:1px solid var(--color-line);font-size:14px;font-weight:600;color:var(--color-text-soft);min-height:40px}.sub-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.list-tile{background:var(--color-surface);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;gap:12px;min-height:60px}.list-tile h3{font-size:16px;font-weight:700}.list-tile p{margin:2px 0 0;font-size:13px;color:var(--color-text-soft)}.list-tile .grow{flex:1}.toast{position:fixed;bottom:calc(96px + var(--safe-bottom));left:50%;transform:translate(-50%);background:var(--color-text);color:#fff;padding:10px 18px;border-radius:999px;font-weight:600;font-size:14px;z-index:200;box-shadow:var(--shadow-card)}.error-banner{background:#b8492c1f;color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-md);font-size:14px;margin:12px 16px}.loading{text-align:center;padding:60px 20px;color:var(--color-text-soft)}.weekday-strip{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.weekday-chip{padding:6px 10px;border-radius:999px;background:var(--color-surface);border:1px solid var(--color-line);font-size:13px;font-weight:600;min-height:36px;min-width:44px;display:flex;align-items:center;justify-content:center}.weekday-chip.active{background:var(--color-secondary);border-color:var(--color-secondary);color:#fff}
