.header{position:sticky;top:0;z-index:10;padding-top:calc(var(--space-3) + var(--safe-top, 0px));padding-bottom:var(--space-3);padding-left:var(--space-4);padding-right:var(--space-4);display:grid;grid-template-columns:32px 1fr 40px;align-items:center;gap:var(--space-3);background:color-mix(in srgb,var(--bg-primary) 88%,transparent);backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--border-subtle)}.header-title{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary);margin:0}.header-slot{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);border-radius:var(--radius-full);transition:transform var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.header-slot:active{transform:scale(.92);background:var(--bg-tertiary)}.header-slot:last-child{justify-self:end}.header-logo{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;overflow:hidden}.header-logo svg{display:block;border-radius:8px}.tabbar{position:sticky;bottom:0;z-index:20;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--space-3);padding-left:var(--space-5);padding-right:var(--space-5);padding-top:var(--space-2);padding-bottom:calc(var(--space-2) + var(--safe-bottom, 0px));background:color-mix(in srgb,var(--bg-secondary) 90%,transparent);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-top:1px solid var(--border-default)}.tab{min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-muted);transition:color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.tab:active{transform:scale(.96)}.tab.is-active{color:var(--accent)}.tab-label{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.02em}.tab.is-active .tab-label{font-weight:600}.tab-add{padding:0 var(--space-2)}.fab{width:56px;height:56px;border-radius:var(--radius-full);background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #2d6a4f66;transform:translateY(-14px);transition:transform var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.tab-add:active .fab{background:var(--accent-hover);transform:translateY(-12px) scale(.96)}.sheet-backdrop{position:fixed;inset:0;z-index:50;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:0;pointer-events:auto;cursor:default;animation:sheet-backdrop var(--duration-normal) var(--ease-out)}@keyframes sheet-backdrop{0%{opacity:0}to{opacity:1}}.sheet{position:fixed;left:0;right:0;bottom:0;z-index:51;pointer-events:auto;background:var(--bg-secondary);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);max-height:88vh;max-height:88dvh;overflow-y:auto;padding:var(--space-3) var(--space-4) calc(var(--space-5) + var(--safe-bottom, 0px));animation:sheet-in var(--duration-normal) var(--ease-out);will-change:transform}@keyframes sheet-in{0%{transform:translate3d(0,16px,0);opacity:0}to{transform:translateZ(0);opacity:1}}.sheet-handle{width:36px;height:4px;border-radius:var(--radius-full);background:#d4d4d4;margin:0 auto var(--space-3)}.photo-input{width:100%}.photo-input__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px dashed var(--border-strong)}.photo-big{display:inline-flex;flex-direction:column;align-items:center;gap:8px;padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);background:var(--accent);color:#fff;font-family:var(--font-display);font-size:15px;font-weight:600;transition:background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.photo-big:active{background:var(--accent-hover);transform:scale(.97)}.photo-small{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--accent);padding:8px 16px}.photo-input__preview{display:flex;flex-direction:column;gap:var(--space-3)}.photo-input__preview img{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius-lg);background:var(--bg-tertiary)}.photo-input__preview-actions{display:flex;gap:var(--space-2);justify-content:center}.photo-ghost{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--accent);padding:8px 14px;border-radius:var(--radius-full);background:var(--accent-light);transition:background var(--duration-fast) var(--ease-out)}.photo-ghost:active{background:var(--accent-bg)}.photo-ghost--muted{color:var(--text-secondary);background:var(--bg-tertiary)}.capture{display:flex;flex-direction:column;gap:var(--space-4)}.capture-header{position:sticky;top:0;z-index:2;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding-top:var(--space-2);padding-bottom:var(--space-3);margin-top:calc(-1 * var(--space-2));background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.capture-title{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.01em;text-align:center;margin:0}.capture-cancel,.capture-save{font-family:var(--font-body);font-size:15px;font-weight:500;padding:6px 2px}.capture-cancel{color:var(--text-secondary);justify-self:start}.capture-save{color:var(--accent);font-weight:600;justify-self:end}.capture-save[disabled]{color:var(--text-disabled)}.field{display:flex;flex-direction:column;gap:8px}.field-label{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:baseline}.field-optional{font-weight:400;color:var(--text-muted);font-size:11px}.field-input{width:100%;min-height:52px;padding:0 var(--space-4);font-family:var(--font-body);font-size:15px;color:var(--text-primary);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1.5px solid transparent;transition:border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.field-input:focus{border-color:var(--accent);background:var(--bg-secondary)}.field-input--date{font-variant-numeric:tabular-nums}.field-hint{font-family:var(--font-body);font-size:12px;color:var(--text-muted)}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{min-height:40px;padding:0 var(--space-4);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid transparent;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.chip:active{transform:scale(.97)}.chip--active{background:var(--accent);color:#fff}.settings{display:flex;flex-direction:column;gap:var(--space-5);padding-bottom:var(--space-3)}.settings-header{padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.settings-title{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.01em;text-align:center;margin:0}.settings-section{display:flex;flex-direction:column;gap:var(--space-1);background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden}.settings-section-head{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4) var(--space-2);color:var(--text-secondary)}.settings-section-label{font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.settings-notice{font-family:var(--font-body);font-size:13px;line-height:1.5;padding:var(--space-3) var(--space-4);margin:0}.settings-notice--warn{color:var(--text-secondary);background:color-mix(in srgb,var(--expiry-soon) 12%,transparent);border-left:3px solid var(--expiry-soon)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bg-secondary);min-height:64px}.settings-row+.settings-row{border-top:1px solid var(--border-subtle)}.settings-row--select{flex-direction:column;align-items:flex-start;gap:var(--space-3);padding-bottom:var(--space-4)}.settings-row--info{min-height:auto;padding-top:var(--space-3);padding-bottom:var(--space-3)}.settings-row--disabled{opacity:.45;pointer-events:none}.settings-row-content{display:flex;flex-direction:column;gap:3px;flex:1}.settings-row-title{font-family:var(--font-body);font-size:15px;font-weight:500;color:var(--text-primary)}.settings-row-sub{font-family:var(--font-body);font-size:12px;color:var(--text-muted);line-height:1.4}.settings-row-value{font-family:var(--font-body);font-size:15px;color:var(--text-secondary)}.settings-row-value--muted{color:var(--text-muted)}.toggle{flex-shrink:0;width:50px;height:30px;border-radius:var(--radius-full);background:var(--border-default);position:relative;transition:background var(--duration-fast) var(--ease-out)}.toggle--on{background:var(--accent)}.toggle-thumb{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:var(--radius-full);background:#fff;box-shadow:0 1px 4px #0003;transition:transform var(--duration-fast) var(--ease-spring)}.toggle--on .toggle-thumb{transform:translate(20px)}.cadence-pills{display:flex;gap:8px;flex-wrap:wrap}.cadence-pill{min-height:36px;padding:0 var(--space-4);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);border:1.5px solid var(--border-default);transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.cadence-pill--active{background:var(--accent);color:#fff;border-color:var(--accent)}.settings-test-btn{margin:0 var(--space-4) var(--space-3);align-self:flex-start;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--accent);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1.5px solid var(--accent);transition:background var(--duration-fast) var(--ease-out)}.settings-test-btn:active{background:color-mix(in srgb,var(--accent) 10%,transparent)}.settings-test-btn:disabled{opacity:.55}.settings-test-status{margin:0 var(--space-4) var(--space-3);font-family:var(--font-body);font-size:12px;line-height:1.4}.settings-test-status--info{color:var(--text-muted)}.settings-test-status--success{color:var(--accent)}.settings-test-status--error{color:var(--expiry-urgent, #b4453a)}.settings-link{flex-shrink:0;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--accent);background:none;border:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.settings-link:active{background:var(--accent-bg)}.person-picker{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:var(--space-5);background:var(--bg-primary);padding-top:calc(var(--safe-top) + var(--space-5));padding-bottom:calc(var(--safe-bottom) + var(--space-5))}.person-picker-card{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4)}.person-picker-logo{margin-bottom:var(--space-2)}.person-picker-title{font-family:var(--font-display);font-weight:600;font-size:28px;line-height:1.2;color:var(--text-primary);margin:0;letter-spacing:-.01em}.person-picker-sub{font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--text-secondary);margin:0;max-width:32ch}.person-picker-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);width:100%;margin-top:var(--space-3)}.person-picker-btn{appearance:none;border:1px solid var(--border-default);background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-4);font-family:var(--font-display);font-weight:600;font-size:22px;color:var(--text-primary);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.person-picker-btn:hover{border-color:var(--accent);background:var(--accent-light)}.person-picker-btn:active{transform:scale(.98)}.person-picker-foot{font-family:var(--font-body);font-size:13px;color:var(--text-muted);margin:0;margin-top:var(--space-2)}.toast-root{position:fixed;left:0;right:0;bottom:calc(88px + var(--safe-bottom, 0px));display:flex;justify-content:center;z-index:60;pointer-events:none}.toast{pointer-events:auto;background:#1a1a1a;color:#fff;padding:12px 16px;border-radius:var(--radius-md);box-shadow:0 10px 30px #00000040;font-family:var(--font-body);font-size:14px;display:flex;align-items:center;gap:var(--space-3);max-width:92%;animation:toast-in var(--duration-slow) var(--ease-spring)}@keyframes toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast-msg{max-width:60vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-action{color:#7ed6b0;font-weight:600;font-size:14px;padding:2px 4px}.expiry-badge{width:10px;height:10px;border-radius:var(--radius-full);display:inline-block;box-shadow:0 0 0 2px #fffffff2}.expiry-badge--urgent,.expiry-badge--past{background:var(--expiry-urgent)}.expiry-badge--soon{background:var(--expiry-soon)}.location-pill{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary);max-width:100%}.location-pill svg{color:var(--text-muted);flex-shrink:0}.location-pill__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:0 2px 12px #0000000f;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow var(--duration-normal) var(--ease-out)}.card--expanded{box-shadow:0 4px 22px #0000001a}.card-main{display:flex;flex-direction:row;align-items:stretch;text-align:left;padding:0;gap:var(--space-3);transition:background var(--duration-fast) var(--ease-out)}.card-main:active{background:var(--bg-tertiary)}.card-photo{position:relative;width:92px;flex-shrink:0;aspect-ratio:1 / 1;color:var(--text-muted);display:flex;align-items:center;justify-content:center;overflow:hidden}.card-photo img{width:100%;height:100%;object-fit:cover}.card-photo__placeholder{opacity:.55}.card-photo__gradient{position:absolute;inset:auto 0 0;height:38%;background:linear-gradient(transparent,#00000047);pointer-events:none}.card-cat{position:absolute;left:8px;bottom:8px;padding:3px 9px;border-radius:var(--radius-full);background:#ffffffeb;color:var(--text-primary);font-family:var(--font-body);font-size:10px;font-weight:600;letter-spacing:.02em}.card-badge{position:absolute;top:8px;right:8px}.card-body{flex:1;min-width:0;padding:var(--space-3) var(--space-4) var(--space-3) 0;display:flex;flex-direction:column;justify-content:center;gap:4px}.card-line{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.card-name{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.card-expiry{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-muted);flex-shrink:0}.card-expiry--urgent,.card-expiry--past{color:var(--expiry-urgent);font-weight:600}.card-expiry--soon{color:var(--expiry-soon);font-weight:600}.card-location{margin-top:2px}.card-actions{display:grid;grid-template-columns:1fr auto auto;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-subtle);background:var(--bg-primary);animation:actions-in var(--duration-normal) var(--ease-spring)}@keyframes actions-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.action{min-height:40px;padding:0 var(--space-4);font-family:var(--font-display);font-size:14px;font-weight:600;border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-default);transition:background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.action:active{transform:scale(.97);background:var(--bg-tertiary)}.action--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.action--primary:active{background:var(--accent-hover)}.action--destructive{color:var(--expiry-urgent);border-color:color-mix(in srgb,var(--expiry-urgent) 24%,transparent);background:var(--expiry-urgent-bg)}.action--destructive:active{background:var(--expiry-urgent);color:#fff}.empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-6) var(--space-5);gap:var(--space-3);min-height:50vh}.empty-illo{width:96px;height:96px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.empty-illo--positive{background:var(--success-bg);color:var(--success)}.empty-title{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary);margin:0}.empty-body{font-family:var(--font-body);font-size:14px;color:var(--text-secondary);max-width:320px;margin:0;line-height:1.5}.empty-cta{margin-top:var(--space-3);min-height:48px;padding:0 var(--space-6);background:var(--accent);color:#fff;font-family:var(--font-display);font-size:15px;font-weight:600;border-radius:var(--radius-md);box-shadow:0 4px 18px #2d6a4f47;transition:background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.empty-cta:active{transform:scale(.97);background:var(--accent-hover)}.feed{flex:1;display:flex;flex-direction:column}.feed-filter{display:flex;gap:8px;padding:var(--space-3) var(--space-4);background:var(--bg-primary);position:sticky;top:0;z-index:5}.feed-chip{flex-shrink:0;min-height:36px;padding:0 var(--space-4);font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.feed-chip:active{transform:scale(.97)}.feed-chip--active{background:var(--accent);color:#fff;font-weight:600}.feed-list{list-style:none;margin:0;padding:0 var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.feed-empty-filter{padding:var(--space-6) var(--space-5);text-align:center;color:var(--text-muted);font-size:14px}.feed-empty-filter button{margin-top:var(--space-3);padding:8px 18px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);font-weight:600}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-primary);max-width:560px;margin-inline:auto;width:100%}.app-main{flex:1;display:flex;flex-direction:column;padding-bottom:calc(88px + var(--safe-bottom, 0px))}.app-loaderror{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-6) var(--space-5);text-align:center;font-family:var(--font-body);color:var(--text-secondary)}.app-loaderror-retry{appearance:none;border:1px solid var(--border-default);background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-2) var(--space-5);font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-primary);cursor:pointer}.feed-loading{flex:1;min-height:160px}:root{--bg-primary: #FAFAF8;--bg-secondary: #FFFFFF;--bg-tertiary: #F5F5F3;--text-primary: #1A1A1A;--text-secondary: #4A4A4A;--text-muted: #9A9A9A;--text-disabled: #C4C4C4;--border-default: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .16);--border-subtle: rgba(0, 0, 0, .04);--accent: #2D6A4F;--accent-hover: #235A42;--accent-bg: #EBF5F0;--accent-light: #F0FAF5;--expiry-urgent: #DC2626;--expiry-urgent-bg: #FEF2F2;--expiry-soon: #D97706;--expiry-soon-bg: #FFFBEB;--success: #16A34A;--success-bg: #F0FDF4;--info: #0284C7;--info-bg: #F0F9FF;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--font-display: "DM Sans", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--duration-fast: .15s;--duration-normal: .22s;--duration-slow: .28s;--duration-dismiss: .32s;--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-out: ease-out;--ease-in: ease-in;--ease: ease;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 999px;--safe-top: env(safe-area-inset-top);--safe-bottom: env(safe-area-inset-bottom);--safe-left: env(safe-area-inset-left);--safe-right: env(safe-area-inset-right)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent}body{font-size:15px;line-height:1.5}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;cursor:pointer;-webkit-appearance:none;appearance:none}input,textarea,select{font-family:inherit;color:inherit;background:none;border:none;outline:none;-webkit-appearance:none;appearance:none}input::placeholder{color:var(--text-muted)}img{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}.t-display{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.1;letter-spacing:-.02em}.t-h1{font-family:var(--font-display);font-size:22px;font-weight:700;line-height:1.2;letter-spacing:-.01em}.t-h2{font-family:var(--font-display);font-size:18px;font-weight:600;line-height:1.3}.t-body{font-size:15px;line-height:1.6}.t-body-sm{font-size:13px;line-height:1.5}.t-label{font-size:11px;font-weight:500;letter-spacing:.04em;line-height:1.4;text-transform:uppercase;color:var(--text-secondary)}.scroll-x{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.scroll-x::-webkit-scrollbar{display:none}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
