.scanner-overlay{position:fixed;inset:0;background:#1a1a1a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.scanner-modal{background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:min(100%,420px);max-height:92vh;overflow-y:auto;display:flex;flex-direction:column}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:var(--border-w) solid var(--ink);background:var(--butter);border-top-left-radius:calc(var(--radius-xl) - 2px);border-top-right-radius:calc(var(--radius-xl) - 2px)}.scanner-header h2{font-family:var(--font-display);font-size:22px;letter-spacing:-.02em;color:var(--ink)}.close-btn{width:36px;height:36px;border:1.5px solid var(--ink);background:#fff;border-radius:50%;font-family:var(--font-display);font-size:18px;color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer}.close-btn:active{transform:scale(.94)}.scan-mode-selector{display:flex;gap:8px;padding:14px 16px;background:var(--cream);border-bottom:var(--border-w) solid var(--ink)}.mode-btn{flex:1;padding:10px 14px;border:var(--border-w) solid var(--ink);border-radius:999px;background:#fff;color:var(--ink);font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:-.01em;cursor:pointer}.mode-btn.active{background:var(--ink);color:var(--butter);box-shadow:var(--shadow-sm)}.scanner-content{position:relative;aspect-ratio:4 / 3;background:var(--ink);overflow:hidden;margin:14px 16px 0;border:var(--border-w) solid var(--ink);border-radius:var(--radius-md)}.camera-view{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.camera-view video{width:100%;height:100%;object-fit:cover}.camera-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--butter);background:#1a1a1ab3;font-family:var(--font-mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.camera-error{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;color:var(--ink);background:var(--coral);font-size:14px;font-weight:500}.scanner-loading-bar{margin:12px 16px 0;padding:12px 14px;background:var(--butter);border:var(--border-w) solid var(--ink);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;text-align:center;color:var(--ink)}.capture-btn{position:absolute;bottom:14px;left:50%;transform:translate(-50%);width:64px;height:64px;border:3px solid var(--ink);border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px #fff,var(--shadow-sm);cursor:pointer}.capture-btn:active{transform:translate(-50%) scale(.95)}.capture-btn:disabled{opacity:.5;cursor:not-allowed}.scan-results{padding:20px;display:flex;flex-direction:column;gap:16px}.result-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.result-name{font-family:var(--font-display);font-size:22px;line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin:0}.result-brand{font-size:12px;color:var(--ink);opacity:.7;margin:4px 0 0}.result-confidence{display:inline-block;padding:4px 10px;background:var(--mint);border:1.5px solid var(--ink);border-radius:999px;font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--ink);letter-spacing:.06em}.result-source{font-family:var(--font-mono);font-size:9px;font-weight:700;color:var(--ink);opacity:.7;text-transform:uppercase;letter-spacing:.12em;margin:6px 0 0}.nutrition-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.nutrition-item{padding:14px 12px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:var(--radius-md);text-align:center}.nutrition-item.calories{background:var(--coral);grid-column:span 2;padding:18px 12px}.nutrition-value{font-family:var(--font-display);font-size:22px;line-height:1;letter-spacing:-.02em;color:var(--ink)}.nutrition-item.calories .nutrition-value{font-size:34px}.nutrition-label{font-family:var(--font-mono);font-size:9px;font-weight:700;color:var(--ink);opacity:.7;text-transform:uppercase;letter-spacing:.12em;margin-top:4px}.serving-size{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--ink);opacity:.7;text-transform:uppercase;letter-spacing:.1em;text-align:center}.favorite-toggle{padding:10px 14px;background:#fff;color:var(--ink);border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer}.favorite-toggle:active{transform:translate(1px,1px)}.favorite-toggle.saved{background:var(--butter);cursor:default}.favorite-toggle:disabled{opacity:.7}.result-actions{display:flex;gap:8px}.result-actions button{flex:1;padding:12px 14px;border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-display);font-size:14px;letter-spacing:-.01em;cursor:pointer}.btn-secondary{background:#fff;color:var(--ink)}.btn-primary{background:var(--ink);color:var(--butter);box-shadow:var(--shadow-sm)}.btn-primary:active,.btn-secondary:active{transform:translate(1px,1px);box-shadow:none}.food-editor{padding:20px;display:flex;flex-direction:column;gap:14px}.editor-title{font-family:var(--font-display);font-size:20px;letter-spacing:-.02em;color:var(--ink);margin:0}.editor-field{display:flex;flex-direction:column;gap:4px}.editor-field label{font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.12em}.editor-field input{padding:10px 12px;border:var(--border-w) solid var(--ink);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:15px;font-weight:500;background:#fff;color:var(--ink)}.editor-field input:focus{outline:none;box-shadow:var(--shadow-sm)}.editor-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.editor-actions{display:flex;gap:8px;margin-top:4px}.editor-actions button{flex:1;padding:12px 14px;border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-display);font-size:14px;letter-spacing:-.01em;cursor:pointer}.barcode-reader{width:100%;height:100%;position:relative}.barcode-reader video{width:100%!important;height:100%!important;object-fit:cover!important}#barcode-reader__scan_region{background:transparent!important}#barcode-reader__dashboard_section,#barcode-reader__dashboard_section_csr,#barcode-reader__dashboard_section_swaplink,#barcode-reader__header_message{display:none!important}.app-page{position:relative;z-index:1;min-height:100dvh;display:flex;justify-content:center;padding:clamp(0rem,4vw,2rem) clamp(0rem,3vw,2rem)}.app-shell{position:relative;width:100%;max-width:420px;background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:28px;overflow:hidden;padding-bottom:calc(110px + env(safe-area-inset-bottom,0px));box-shadow:var(--shadow-lg)}@media (max-width: 480px){.app-page{padding:0}.app-shell{border-radius:0;border:0;box-shadow:none;min-height:100dvh}}.header-block,.view-header{padding-top:calc(28px + env(safe-area-inset-top,0px))}.tab-bar{bottom:calc(18px + env(safe-area-inset-bottom,0px))}.header-block{background:var(--header-bg, var(--lavender));border-bottom:var(--border-w) solid var(--ink);padding:28px 18px 22px;position:relative}.nav-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:20px}.nav-row .spacer{flex:1}.nav-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;color:var(--ink);border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:-.01em;cursor:pointer}.nav-pill.active{background:var(--ink);color:var(--butter);box-shadow:var(--shadow-sm)}.nav-pill.active:before{content:"";width:8px;height:8px;background:var(--butter);border-radius:50%}.nav-pill.butter{background:var(--butter)}.hero{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.hero-text{flex:1;min-width:0}.hero-title{font-family:var(--font-display);font-size:44px;line-height:.92;letter-spacing:-.035em;color:var(--ink);margin:8px 0 0}.hero-sub{margin-top:10px;font-size:13px;line-height:1.45;color:var(--ink);opacity:.8;max-width:200px}.pixel-portrait{width:76px;height:76px;border:var(--border-w) solid var(--ink);border-radius:var(--radius-md);overflow:hidden;box-shadow:3px 3px 0 var(--ink);flex-shrink:0;background:var(--butter);padding:0;cursor:pointer}.pixel-portrait:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}.pixel-portrait img{width:100%;height:100%;display:block;image-rendering:pixelated}.step-ring-card{margin-top:20px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:18px;padding:14px;box-shadow:var(--shadow-md)}.step-ring-button{width:100%;cursor:pointer;text-align:left;font:inherit;color:inherit;display:flex;align-items:center;gap:14px;position:relative}.step-ring-button:active{transform:translate(1px,1px);box-shadow:var(--shadow-sm)}.step-ring-edit{position:absolute;top:10px;right:12px;font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);opacity:.55}.week-chart{margin-top:14px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:18px;padding:14px;box-shadow:var(--shadow-md)}.week-chart-eyebrow{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.week-chart-bars{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;align-items:end}.week-chart-col{display:flex;flex-direction:column;align-items:center;gap:6px}.week-chart-track{width:100%;height:72px;background:var(--cream);border:1.5px solid var(--ink);border-radius:8px;position:relative;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}.week-chart-bar{width:70%;background:var(--lavender);border-top:1.5px solid var(--ink);border-bottom:0;transition:height .4s ease}.week-chart-bar.today{background:var(--coral)}.week-chart-goal{position:absolute;left:0;right:0;height:0;border-top:1.5px dashed var(--ink);opacity:.4;pointer-events:none}.week-chart-label{font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--ink);opacity:.7;letter-spacing:.08em}.step-ring-block{display:flex;align-items:center;gap:14px}.step-ring-svg{position:relative;width:92px;height:92px;flex-shrink:0}.step-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.step-ring-value{font-family:var(--font-display);font-size:20px;line-height:1;color:var(--ink)}.step-ring-label{font-family:var(--font-mono);font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-top:2px;color:var(--ink)}.step-ring-pct,.step-ring-goal{font-family:var(--font-display);font-size:15px;line-height:1.1;color:var(--ink)}.step-ring-pct{margin-top:2px}.scan-card{margin:20px 18px 0;background:var(--coral);border:var(--border-w) solid var(--ink);border-radius:var(--radius-xl);padding:18px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-md);cursor:pointer;text-align:left;width:calc(100% - 36px);font:inherit;color:inherit}.scan-card:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--ink)}.icon-badge{width:52px;height:52px;border-radius:50%;border:var(--border-w) solid var(--ink);background:var(--butter);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.icon-badge.sm{width:40px;height:40px;background:#fff}.scan-copy{flex:1;min-width:0}.scan-copy h2{font-family:var(--font-display);font-size:22px;line-height:1;margin-top:4px;letter-spacing:-.02em}.scan-sub{font-size:12px;opacity:.8;margin-top:4px}.scan-arrow{width:56px;height:56px;flex-shrink:0;background:var(--ink);color:var(--butter);border:var(--border-w) solid var(--ink);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;box-shadow:var(--shadow-sm)}.section{padding:20px 18px 0}.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;gap:12px}.section-title{font-family:var(--font-display);font-size:18px;letter-spacing:-.02em}.section-head .eyebrow{opacity:.7}.stat-head-right{display:flex;align-items:center;gap:8px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-card{background:var(--stat-bg, var(--mint));border:var(--border-w) solid var(--ink);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-md);display:flex;flex-direction:column}.stat-card .stat-value{font-family:var(--font-display);font-size:28px;line-height:1;margin-top:6px;letter-spacing:-.02em;color:var(--ink)}.stat-card .eyebrow{margin-top:12px}.stat-detail{font-size:12px;line-height:1.45;color:var(--ink);opacity:.85;margin-top:6px}.chip{display:inline-flex;align-items:center;padding:3px 10px 4px;background:var(--chip-bg, var(--chip-orange));color:var(--ink);border:1.5px solid var(--ink);border-radius:999px;font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;line-height:1.2;width:fit-content}.stat-card .chip{margin-top:10px}.meal-log-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.meal-empty{width:100%;display:flex;align-items:center;gap:12px;padding:16px 14px;background:var(--cream);border:var(--border-w) dashed var(--ink);border-radius:var(--radius-md);font:inherit;color:inherit;text-align:left;cursor:pointer}.meal-empty:hover{background:var(--butter)}.meal-empty-title{font-family:var(--font-display);font-size:16px;line-height:1;letter-spacing:-.02em}.meal-empty-hint{font-size:12px;opacity:.75;margin-top:3px;line-height:1.35}.meal-empty-arrow{margin-left:auto;width:36px;height:36px;flex-shrink:0;background:var(--ink);color:var(--butter);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:16px}.quicklog{padding-top:20px;padding-bottom:0}.quicklog-strip{display:flex;gap:10px;overflow-x:auto;padding:4px 0 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.quicklog-strip::-webkit-scrollbar{display:none}.quicklog-tile{position:relative;flex:0 0 108px;min-height:96px;padding:12px 14px 14px;background:var(--tile-bg, var(--butter));border:var(--border-w) solid var(--ink);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);font:inherit;color:inherit;text-align:left;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;scroll-snap-align:start}.quicklog-tile:active{transform:translate(1px,1px);box-shadow:none}.quicklog-kcal{font-family:var(--font-display);font-size:22px;line-height:1;letter-spacing:-.02em}.quicklog-name{margin-top:8px;font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:-.01em;line-height:1.15}.quicklog-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#ffffffb3;border:1.5px solid var(--ink);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:11px;line-height:1;color:var(--ink);cursor:pointer}.plan-section{display:flex;flex-direction:column;gap:14px}.plan-week-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px}.plan-summary-tile{background:#fff;border:var(--border-w) solid var(--ink);border-radius:var(--radius-md);padding:12px 14px;box-shadow:var(--shadow-sm)}.plan-summary-tile.over{background:var(--coral)}.plan-summary-value{font-family:var(--font-display);font-size:22px;line-height:1;letter-spacing:-.02em;margin-top:6px}.plan-shopping-btn{grid-column:span 2;padding:14px;background:var(--ink);color:var(--butter);border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-display);font-size:14px;letter-spacing:-.01em;box-shadow:var(--shadow-sm);cursor:pointer}.plan-shopping-btn:active{transform:translate(1px,1px);box-shadow:none}.shopping-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.shopping-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:1.5px solid var(--ink);border-radius:var(--radius-sm);cursor:pointer}.shopping-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--ink)}.shopping-row.checked .shopping-name,.shopping-row.checked .shopping-qty{text-decoration:line-through;opacity:.45}.shopping-name{flex:1;font-family:var(--font-body);font-size:14px;font-weight:600}.shopping-qty{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.7}.reminders-card{background:var(--sky);border:var(--border-w) solid var(--ink);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-md)}.reminders-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.reminders-cycles{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.reminders-times{display:flex;flex-direction:column;gap:6px;margin-top:6px}.reminders-time-row{display:flex;gap:6px;align-items:center}.reminders-time-row input[type=time]{flex:1;padding:8px 12px;border:1.5px solid var(--ink);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;background:#fff}.reminders-time-row .meal-delete{margin:0}.switch{position:relative;display:inline-block;width:52px;height:30px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch-slider{position:absolute;inset:0;background:#fff;border:var(--border-w) solid var(--ink);border-radius:999px;cursor:pointer;transition:background .15s}.switch-slider:before{content:"";position:absolute;left:2px;top:2px;width:22px;height:22px;background:var(--ink);border-radius:50%;transition:transform .15s}.switch input:checked+.switch-slider{background:var(--butter)}.switch input:checked+.switch-slider:before{transform:translate(22px)}.plan-loading{padding:24px 0;text-align:center;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.6}.plan-day{background:#fff;border:var(--border-w) solid var(--ink);border-radius:var(--radius-lg);padding:14px;box-shadow:var(--shadow-sm)}.plan-day.today{background:var(--butter)}.plan-day-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.plan-day-label{font-family:var(--font-display);font-size:18px;letter-spacing:-.02em;line-height:1}.plan-day-total{text-align:right}.plan-day-total.over .meal-kcal{color:#b4302a}.plan-slots{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.plan-slot{background:var(--cream);border:1.5px solid var(--ink);border-radius:var(--radius-md);padding:8px 10px;min-height:70px;display:flex;flex-direction:column;gap:4px;position:relative}.plan-slot.filled{background:#fff}.plan-slot-label{font-family:var(--font-mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;opacity:.6}.plan-slot-body{display:flex;flex-direction:column;gap:2px}.plan-slot-name{font-family:var(--font-body);font-size:13px;font-weight:700;line-height:1.15;letter-spacing:-.01em}.plan-slot-meta{font-size:11px;opacity:.7}.plan-slot-add{all:unset;cursor:pointer;flex:1;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:12px;font-weight:700;opacity:.6}.plan-slot .meal-delete{position:absolute;top:4px;right:4px;width:22px;height:22px;font-size:13px;margin:0}.picker-modal{max-width:420px;max-height:80vh;overflow-y:auto}.picker-categories{display:flex;gap:6px;flex-wrap:wrap}.picker-search{width:100%;padding:10px 12px;border:var(--border-w) solid var(--ink);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;background:#fff}.picker-search:focus{outline:none;box-shadow:var(--shadow-sm)}.picker-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.picker-empty{padding:20px 0;text-align:center;opacity:.6;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em}.picker-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:1.5px solid var(--ink);border-radius:var(--radius-md);font:inherit;color:inherit;text-align:left;cursor:pointer}.picker-item:hover{background:var(--butter)}.picker-item-main{flex:1;min-width:0}.picker-item-name{font-family:var(--font-body);font-size:14px;font-weight:700;letter-spacing:-.01em}.picker-item-meta{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.6;margin-top:2px}.picker-item-kcal{text-align:right}.meal-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:var(--radius-md)}.meal-thumb{width:46px;height:46px;flex-shrink:0;background:repeating-linear-gradient(45deg,var(--mint) 0 6px,var(--cream) 6px 12px);border:var(--border-w) solid var(--ink);border-radius:10px}.meal-main{flex:1;min-width:0}.meal-name{font-size:14px;font-weight:700;letter-spacing:-.01em}.meal-meta{font-size:11px;opacity:.7;margin-top:1px}.meal-chips{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap}.meal-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:2px}.meal-kcal{font-family:var(--font-display);font-size:16px;line-height:1}.kcal-label{font-family:var(--font-mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.meal-action{margin-top:8px;padding:4px 10px;background:var(--ink);color:var(--butter);border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-body);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.meal-delete{flex-shrink:0;width:28px;height:28px;margin-left:4px;padding:0;background:transparent;border:1.5px solid var(--ink);border-radius:50%;font-family:var(--font-display);font-size:16px;line-height:1;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.meal-delete:hover{background:var(--coral)}.meal-delete:active{transform:scale(.92)}.tab-bar{position:absolute;bottom:18px;left:16px;right:16px;background:var(--ink);border:var(--border-w) solid var(--ink);border-radius:999px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;gap:4px;box-shadow:4px 4px 0 var(--butter)}.tab{flex:1;text-align:center;padding:8px 0;border-radius:999px;font-family:var(--font-body);font-size:12px;font-weight:700;color:#fff;letter-spacing:-.01em;border:var(--border-w) solid transparent;background:transparent}.tab.active{background:var(--tab-color, var(--butter));color:var(--ink);border-color:var(--ink)}.top-right-actions{display:inline-flex;gap:8px;align-items:center}.view-header{padding:44px 18px 8px;background:var(--lavender);border-bottom:var(--border-w) solid var(--ink)}.view-title{font-family:var(--font-display);font-size:36px;line-height:.95;letter-spacing:-.03em;color:var(--ink);margin:6px 0 14px}.day-group{margin-bottom:18px}.day-group-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.you-section{display:flex;flex-direction:column;gap:14px}.you-profile-card{display:flex;align-items:center;gap:14px;width:100%;padding:14px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:left;color:inherit;font:inherit;cursor:pointer}.you-portrait{margin:0;width:64px;height:64px;box-shadow:2px 2px 0 var(--ink)}.you-name{font-family:var(--font-display);font-size:22px;letter-spacing:-.02em;line-height:1;margin-top:4px}.you-profile-card .scan-arrow{width:36px;height:36px;font-size:16px;margin-left:auto}.you-goal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.you-goal-card{padding:14px;background:var(--butter);border:var(--border-w) solid var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.you-goal-card:nth-child(2){background:var(--mint)}.you-goal-value{font-family:var(--font-display);font-size:26px;line-height:1;letter-spacing:-.02em;margin-top:6px}.you-lang-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:var(--radius-md)}.you-edit-btn{padding:14px 18px;background:var(--ink);color:var(--butter);border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-display);font-size:15px;letter-spacing:-.01em;box-shadow:var(--shadow-sm);cursor:pointer}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;z-index:1}.login-card{width:100%;max-width:360px;background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.login-badge{width:64px;height:64px;background:var(--butter);border:var(--border-w) solid var(--ink);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:26px;letter-spacing:-.04em;color:var(--ink)}.login-title{font-family:var(--font-display);font-size:32px;letter-spacing:-.03em;margin-top:4px}.login-sub{font-size:14px;opacity:.75;line-height:1.4;max-width:280px}.login-error{width:100%;padding:10px 12px;background:var(--coral);border:var(--border-w) solid var(--ink);border-radius:var(--radius-sm);font-size:13px;font-weight:600}.login-google{width:100%;margin-top:6px;padding:12px 16px;background:#fff;color:var(--ink);border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-body);font-size:15px;font-weight:700;box-shadow:var(--shadow-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.login-google:active{transform:translate(1px,1px);box-shadow:none}.settings-overlay{position:fixed;inset:0;z-index:900;background:#1a1a1a66;display:flex;align-items:center;justify-content:center;padding:18px}.settings-modal{background:var(--paper);border:var(--border-w) solid var(--ink);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:360px;padding:20px;display:flex;flex-direction:column;gap:14px}.settings-header{display:flex;align-items:center;justify-content:space-between}.settings-header h2{font-family:var(--font-display);font-size:22px;letter-spacing:-.02em}.settings-close{width:32px;height:32px;padding:0;background:transparent;border:1.5px solid var(--ink);border-radius:50%;font-family:var(--font-display);font-size:18px;color:var(--ink);cursor:pointer}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-field input{padding:10px 12px;border:var(--border-w) solid var(--ink);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:15px;font-weight:500;background:#fff;color:var(--ink)}.settings-field input:focus{outline:none;box-shadow:var(--shadow-sm)}.settings-actions{display:flex;gap:8px;margin-top:6px}.settings-btn{flex:1;padding:12px 14px;border:var(--border-w) solid var(--ink);border-radius:999px;font-family:var(--font-display);font-size:14px;letter-spacing:-.01em;cursor:pointer}.settings-btn.ghost{background:#fff;color:var(--ink)}.settings-btn.primary{background:var(--ink);color:var(--butter);box-shadow:var(--shadow-sm)}:root{--ink: #1a1a1a;--paper: #fffbf0;--cream: #fdf6e3;--page-bg: #f4eedd;--lavender: #e0d4f7;--butter: #fbe89a;--mint: #c8f0d6;--coral: #ffc9bc;--sky: #c5e3f7;--chip-orange: #ff9f5a;--chip-teal: #5ec5b9;--chip-green: #7ed88d;--chip-pink: #ff8fa3;--chip-violet: #b794f6;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 20px;--radius-xl: 22px;--border-w: 2px;--shadow-sm: 2px 2px 0 var(--ink);--shadow-md: 4px 4px 0 var(--ink);--shadow-lg: 6px 6px 0 var(--ink);--font-display: "Archivo Black", "Inter", system-ui, sans-serif;--font-body: "Space Grotesk", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--card: #ffffff;--border: rgba(26, 26, 26, .18);--bg-muted: var(--cream);--text: var(--ink);--text-muted: rgba(26, 26, 26, .65);--text-soft: rgba(26, 26, 26, .55);--primary: var(--chip-teal);--primary-strong: var(--ink);--accent-soft: var(--butter);--radius: 16px;--fs-xs: .75rem;--fs-sm: .875rem;--fs-base: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--fs-2xl: 1.75rem}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--page-bg);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;position:relative;overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent}@media (max-width: 480px){body:before{display:none}}@media (hover: none){button,.nav-pill,.tab,.meal-delete,.close-btn{min-height:36px}}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(rgba(26,26,26,.13) 1px,transparent 1px);background-size:22px 22px;opacity:.5}h1,h2,h3,h4{margin:0;font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;line-height:1}p{margin:0}a{color:inherit}button{font:inherit;color:inherit;cursor:pointer}button:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.eyebrow{font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--ink)}.langswitch{display:inline-flex;align-items:center;gap:4px;padding:3px;background:#fff;border:var(--border-w) solid var(--ink);border-radius:999px}.langswitch button{background:transparent;border:0;padding:4px 10px;border-radius:999px;color:var(--ink);font-family:var(--font-body);font-weight:700;font-size:11px;letter-spacing:.04em;text-transform:uppercase}.langswitch button.active{background:var(--ink);color:var(--butter)}
