:root{color:#16201c;background:#f4f5f1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f4f5f1}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{width:min(800px,calc(100% - 24px));margin:0 auto;padding:20px 0 40px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #d8ddd5}.eyebrow{margin:0 0 4px;color:#5d675f;font-size:12px;font-weight:700}h1{margin:0;font-size:28px;font-weight:800;letter-spacing:-.02em}h2{margin:0 0 16px;font-size:14px;font-weight:800;color:#5d675f;text-transform:uppercase;letter-spacing:.05em}.date-controls{display:flex;flex-wrap:wrap;gap:0;align-items:center;justify-content:flex-end}.date-picker{position:relative}.date-picker-button{display:inline-flex;align-items:center;gap:2px;padding:0;border:none;background:transparent;font-size:15px;font-weight:700;color:#16201c;cursor:pointer;white-space:nowrap}.record-name-button{padding:0;border:0;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.date-picker input{position:absolute;opacity:0;width:0;height:0;pointer-events:none;padding:0;margin:0;border:none;overflow:hidden}.date-picker svg{display:block;flex-shrink:0}.date-picker span{line-height:1}input[type=date]::-webkit-datetime-edit{padding:0;margin:0}input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0;margin:0}input[type=date]::-webkit-calendar-picker-indicator{margin:0;padding:0;opacity:.6;width:14px;height:14px}input[type=date]::-webkit-inner-spin-button{display:none}input[type=date]::-webkit-clear-button{display:none}.summary-strip{display:flex;gap:24px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #d8ddd5}.macro{display:flex;flex-direction:column;gap:2px}.macro span{color:#5d675f;font-size:11px;font-weight:700}.macro strong{font-size:20px;font-weight:800;letter-spacing:-.02em}.workspace{display:grid;grid-template-columns:1fr 1fr;gap:40px}.meal-flow{display:grid;gap:20px;min-width:0}.panel{border:none;background:transparent;border-radius:0;min-width:0}.input-panel,.preview-panel{padding:16px;border:1px solid #d8ddd5;border-radius:8px;background:#fff}.log-panel{margin-top:24px;padding-top:24px;border-top:1px solid #d8ddd5}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;min-width:0}.mini-totals{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;min-width:0;font-size:12px;font-weight:700;color:#66736c}.add-mode-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid #e3e7e0;min-width:0}.add-mode-tabs button{display:inline-flex;align-items:center;justify-content:center;gap:6px;flex:1;padding:10px 4px;border:none;border-bottom:2px solid transparent;color:#66736c;background:transparent;font-size:13px;font-weight:800;cursor:pointer}.add-mode-tabs button.active{color:#245f4c;border-bottom-color:#245f4c}.add-mode-panel{display:grid;gap:12px}.input-rows{display:grid;gap:0}.input-row-shell{position:relative;border-bottom:1px solid #e3e7e0}.input-row-shell:last-child{border-bottom:1px solid #d8ddd5}.input-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;background:#fbfcfa;min-width:0}.input-cell{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.row-index{display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;color:#66736c;background:#edf1eb;font-size:11px;font-weight:800}.food-input{width:100%;min-width:0;border:none;background:transparent;color:#16201c;font-size:15px;outline:none;padding:0}.food-input::placeholder{color:#9da8a0}.row-status{display:flex;align-items:center;gap:8px;min-width:0}.row-badge{display:inline-flex;align-items:center;gap:4px;min-width:0;overflow-wrap:anywhere;font-size:12px;font-weight:800;color:#1d5b45}.suggestions-panel{margin:0 0 8px 32px}.product-suggestions{margin:4px 0 0}.suggestion-option{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-width:0;padding:8px 0;border:none;border-bottom:1px solid #edf1eb;color:#16201c;background:transparent;text-align:left;font-size:14px}.suggestion-option:last-child{border-bottom:none}.suggestion-option:hover{color:#245f4c}.suggestion-head{display:flex;align-items:center;gap:6px;min-width:0}.suggestion-option strong{font-weight:600;overflow-wrap:anywhere}.suggestion-option small{color:#66736c;font-size:12px;overflow-wrap:anywhere}.match-tag{display:inline-flex;align-items:center;flex:0 0 auto;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:800}.match-tag.exact{color:#1d5b45;background:#e4f2ea}.add-row-button{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:0;border:none;color:#245f4c;background:transparent;font-size:13px;font-weight:800}.actions{display:flex;gap:10px;margin-top:16px}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 20px;min-height:36px;border:none;border-radius:6px;font-size:13px;font-weight:800;color:#fff;background:#245f4c}.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 20px;min-height:36px;border:1px solid #a8b7ae;border-radius:6px;font-size:13px;font-weight:800;color:#1d473a;background:transparent}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;color:#66736c;background:transparent;padding:0}.icon-button:hover{background:#edf1eb}.preview-list{display:grid;gap:0}.preview-row{display:grid;gap:8px;padding:12px 0;border-bottom:1px solid #e3e7e0;background:transparent;border-radius:0;margin-bottom:0}.preview-row:last-child{border-bottom:none}.item-head{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.item-head>div{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;min-width:0}.item-head strong{font-size:15px;font-weight:600;overflow-wrap:anywhere}.source-badge{display:inline-flex;align-items:center;margin-left:0;padding:2px 6px;border-radius:4px;color:#245f4c;background:#e4f2ea;font-size:11px;font-weight:800}.item-head span{color:#66736c;font-size:13px}.item-head .source-badge{color:#245f4c;font-size:11px}.check-status{display:inline-flex;align-items:center;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:800}.check-status.ready{color:#1d5b45;background:#e4f2ea}.check-status.pending{color:#7b2f22;background:#fae8e4}.amount-fields{display:flex;gap:12px;flex-wrap:wrap}.amount-field{display:inline-flex;align-items:center;gap:6px;font-size:13px}.amount-field span{color:#66736c;font-size:12px;font-weight:700}.amount-field input{width:60px;padding:4px 6px;border:1px solid #d8ddd5;border-radius:4px;background:#fff;color:#16201c;font-size:14px;text-align:right;outline:none}.amount-field input:focus{border-color:#3f7e68}.row-macros{display:flex;flex-wrap:wrap;gap:12px;min-width:0;color:#66736c;font-size:12px;font-weight:700}.check-row-body{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;min-width:0}.check-row-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-left:auto;min-width:0}.new-food-panel{display:grid;gap:12px;padding:12px 0}.search-link-btn{display:inline-flex;align-items:center;gap:6px;padding:0;border:none;color:#245f4c;background:transparent;font-size:13px;font-weight:800;cursor:pointer}.candidate-guide{display:grid;gap:6px;padding:8px 0;font-size:13px;color:#40504a}.candidate-guide strong{color:#1f4f40;font-size:12px}.candidate-guide p{margin:0;line-height:1.5}.candidate-guide ul{margin:0;padding-left:18px}.candidate-guide li{margin:2px 0}.guide-cautions{display:flex;flex-wrap:wrap;gap:6px}.guide-cautions span{padding:2px 6px;border-radius:4px;background:#fff3dc;font-size:11px}.candidate-list{display:grid;gap:0}.candidate-choice{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:10px 0;border-bottom:1px solid #e3e7e0;color:#16201c;background:transparent}.candidate-choice:last-child{border-bottom:none}.candidate-main{display:grid;gap:4px;flex:1;min-width:0}.candidate-title{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.candidate-title em{display:inline-block;padding:2px 6px;border-radius:4px;color:#fff;background:#245f4c;font-size:11px;font-style:normal;font-weight:800;justify-self:start}.candidate-title strong{font-size:14px;font-weight:700;overflow-wrap:anywhere}.candidate-main small{color:#66736c;font-size:12px;overflow-wrap:anywhere}.candidate-action{flex:0 0 auto;padding-inline:14px}.source-link{color:#245f4c;font-size:12px;font-weight:800;text-decoration:none}.source-link:hover{text-decoration:underline}.source-attribution{margin:0;color:#66736c;font-size:11px;line-height:1.4}.source-attribution a{color:#245f4c;font-weight:800;text-decoration:none}.source-attribution a:hover{text-decoration:underline}.food-form{display:grid;gap:8px;padding:8px 0}.food-form label{display:grid;gap:4px}.food-form label span{font-size:12px;font-weight:700;color:#5d675f}.food-form input{padding:6px 8px;border:1px solid #d8ddd5;border-radius:4px;background:#fff;color:#16201c;font-size:14px;outline:none}.food-form input:focus{border-color:#3f7e68;box-shadow:0 0 0 2px #3f7e681a}.nutrient-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.unit-row-inline{display:flex;gap:8px;flex-wrap:wrap}.unit-row-inline label{flex:1;min-width:100px}.log-list{display:grid;gap:0}.log-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px;border-bottom:1px solid #e3e7e0;background:#fbfcfa;border-radius:6px;margin-bottom:8px}.log-row:last-child{border-bottom:none}.log-main{display:flex;flex-direction:column;gap:2px;flex:1}.log-main time{color:#66736c;font-size:12px;font-weight:700}.log-main span{color:#16201c;font-size:14px}.log-macros{display:flex;gap:12px;color:#66736c;font-size:12px;font-weight:700}.log-actions{display:flex;gap:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;background:#00000040;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-panel{width:min(480px,100%);max-height:calc(100vh - 40px);overflow-y:auto;border:1px solid #d8ddd5;border-radius:12px;background:#fff;padding:24px;box-shadow:0 20px 60px #0000001a}.modal-panel .panel-heading{margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e3e7e0}.food-manager-list{display:grid;gap:0;max-height:60vh;overflow-y:auto;margin-bottom:12px}.food-manager-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid #e3e7e0}.food-manager-row:last-child{border-bottom:none}.food-info{display:flex;flex-direction:column;gap:2px;flex:1}.food-info strong{font-size:14px;font-weight:600}.food-info small{color:#66736c;font-size:12px}.food-actions{display:flex;gap:4px}.food-edit-form{display:grid;gap:8px;padding:8px 0}.edit-actions{display:flex;gap:8px;margin-top:4px}.lookup-form{display:grid;gap:12px}.lookup-form label{display:grid;gap:4px}.lookup-form label span{color:#5d675f;font-size:12px;font-weight:700}.lookup-form input{padding:8px 10px;border:1px solid #d8ddd5;border-radius:6px;background:#fff;color:#16201c;font-size:14px;outline:none}.lookup-form input:focus{border-color:#3f7e68;box-shadow:0 0 0 2px #3f7e681a}.scanner-box{display:grid;gap:8px}.scanner-box video{width:100%;aspect-ratio:16 / 9;border:1px solid #d8ddd5;border-radius:6px;background:#16201c;object-fit:cover}.lookup-results{display:grid;gap:10px;margin-top:16px}.invite-panel{width:min(640px,100%)}.invite-toolbar{display:flex;gap:8px;margin-bottom:16px}.invite-list{display:grid;gap:0;max-height:60vh;overflow-y:auto}.invite-row{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid #e3e7e0}.invite-row:last-child{border-bottom:none}.invite-info{display:grid;gap:4px;flex:1;min-width:0}.invite-code-line{display:flex;align-items:center;gap:8px;min-width:0}.invite-code-line code{overflow-wrap:anywhere;color:#16201c;font-size:13px;font-weight:800}.invite-info small{overflow-wrap:anywhere;color:#66736c;font-size:12px}.invite-actions{display:flex;flex:0 0 auto;gap:4px}.status-pill{display:inline-flex;align-items:center;flex:0 0 auto;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:800}.status-pill.available{color:#1d5b45;background:#e4f2ea}.status-pill.used{color:#4f5b68;background:#edf1eb}.status-pill.expired{color:#7b2f22;background:#fae8e4}.copied-label{position:absolute;right:0;bottom:4px;color:#1d5b45;font-size:11px;font-weight:800}.edit-records{display:grid;gap:0;margin-bottom:12px}.edit-record-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #e3e7e0}.edit-record-row:last-child{border-bottom:none}.record-name{flex:1;font-weight:600;font-size:14px;cursor:pointer}.record-name:hover{color:#245f4c}.record-food-select{flex:1}.food-select-list{display:grid;gap:4px;max-height:200px;overflow-y:auto;border:1px solid #e3e7e0;border-radius:6px;padding:4px;background:#fff}.food-select-option{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border:none;border-radius:4px;background:transparent;cursor:pointer;text-align:left;font-size:13px}.food-select-option:hover{background:#f1f6f2}.food-select-option small{font-size:11px;color:#66736c}.notice,.error,.warning{margin:12px 0 0;border-radius:6px;padding:8px 12px;font-size:13px;font-weight:700}.notice{color:#1d5b45;background:#e4f2ea}.error,.warning{color:#7b2f22;background:#fae8e4}.empty-state{padding:40px 12px;color:#9da8a0;text-align:center;font-size:14px}.auth-unavailable{display:grid;justify-items:center;gap:12px}.auth-unavailable p{margin:0}.spin{animation:spin .9s linear infinite}.muted{color:#9da8a0}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:720px){.app-shell{width:calc(100% - 16px);padding-top:12px}.input-panel,.preview-panel{padding:12px}h1{font-size:22px}.summary-strip{gap:16px}.macro strong{font-size:16px}.panel-heading{align-items:flex-start;flex-wrap:wrap}.panel-heading h2{min-width:0}.mini-totals{justify-content:flex-start;width:100%}.workspace{grid-template-columns:1fr;gap:24px}.topbar{flex-direction:column;align-items:flex-start}.date-controls{justify-content:flex-start;width:100%}.log-row{flex-direction:column;align-items:flex-start;gap:8px}.log-macros{width:100%}.actions{flex-direction:column}.actions .primary-button,.actions .secondary-button{width:100%}.input-row{align-items:flex-start;flex-wrap:wrap;padding-inline:10px}.row-status{width:100%;justify-content:flex-end}.suggestions-panel{margin-left:0}.suggestion-option{align-items:flex-start;flex-direction:column;gap:4px}.item-head{align-items:flex-start}.item-head>div{flex:1}.check-row-actions{margin-left:0;width:100%}.add-mode-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-bottom:none}.add-mode-tabs button{border:1px solid #d8ddd5;border-radius:6px;background:#fbfcfa}.add-mode-tabs button.active{border-color:#245f4c;background:#e4f2ea}.candidate-choice{align-items:stretch;flex-direction:column}.candidate-action{width:100%}.auth-card{width:calc(100% - 32px);padding:24px 20px}}.auth-shell{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:#f4f5f1}.auth-card{width:100%;max-width:380px;padding:32px;border:1px solid #d8ddd5;border-radius:12px;background:#fff;box-shadow:0 4px 20px #0000000d}.auth-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid #e3e7e0}.auth-tabs button{flex:1;padding:10px 0;border:none;border-bottom:2px solid transparent;background:transparent;font-size:14px;font-weight:700;color:#66736c;cursor:pointer}.auth-tabs button.active{color:#245f4c;border-bottom-color:#245f4c}.auth-form{display:grid;gap:16px}.auth-form label{display:grid;gap:6px}.auth-form label span{font-size:12px;font-weight:700;color:#5d675f}.auth-form input{padding:10px 12px;border:1px solid #d8ddd5;border-radius:6px;background:#fff;color:#16201c;font-size:15px;outline:none}.auth-form input:focus{border-color:#3f7e68;box-shadow:0 0 0 2px #3f7e681a}.auth-form .primary-button{width:100%;margin-top:4px}
