:root{--color-ivory: #fff8ef;--color-paper: #fffdf8;--color-cream: #f7ead7;--color-porcelain: #fbf4e9;--color-chocolate: #32170f;--color-ganache: #4b2118;--color-cocoa: #7a3f1f;--color-caramel: #c9853d;--color-copper: #9b5a2f;--color-raspberry: #a73d56;--color-pistachio: #4f7f64;--color-pistachio-dark: #2f5f4a;--color-water: #2f6f9f;--color-muted: #786960;--color-border: #e1cdb4;--shadow-soft: 0 18px 48px rgba(75, 33, 24, .12);--radius: 8px;color:var(--color-chocolate);background:var(--color-ivory);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html{background:var(--color-ivory)}body{margin:0;min-width:320px;background:linear-gradient(180deg,#fff8ef,#f8efe1 52%,#fffaf2)}button,input{font:inherit}input{min-width:0}button{cursor:pointer;-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed;opacity:.42}.app-shell{width:min(1180px,100%);margin:0 auto;padding:20px}.app-header{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;padding:8px 0 18px}.brand-lockup{display:flex;align-items:center;gap:13px}.brand-mark{width:52px;height:52px;flex:0 0 auto;border-radius:14px;box-shadow:0 10px 22px #4b211826}.app-header h1{margin:0;color:var(--color-ganache);font-family:ui-serif,Georgia,Times New Roman,serif;font-size:29px;line-height:1.04;font-weight:760}.app-header p,.summary-header p{margin:6px 0 0;color:var(--color-muted);font-size:14px}.header-status{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:9px}.offline-status,.ingredient-count,.recipe-save-state{display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:7px 11px;color:var(--color-ganache);background:#fffdf8db;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 6px 18px #4b21180f}.offline-status strong,.recipe-save-state strong{display:block;font-size:12px;line-height:1.15;font-weight:800}.offline-status small,.recipe-save-state small{display:block;margin-top:2px;color:var(--color-muted);font-size:11px;line-height:1.15}.offline-status.online svg{color:var(--color-pistachio-dark)}.offline-status.offline{color:#7f1d1d;background:#fff0ee;border-color:#f3b8ad}.ingredient-count{color:var(--color-cocoa);font-size:13px;font-weight:800}.app-tabs{display:flex;gap:8px;margin:0 0 18px;overflow-x:auto;scrollbar-width:thin}.app-tabs button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 14px;color:var(--color-ganache);background:#fffdf8db;border:1px solid var(--color-border);border-radius:var(--radius);white-space:nowrap;font-size:13px;font-weight:800}.app-tabs button.active{color:#fffdf8;background:var(--color-ganache);border-color:var(--color-ganache)}.builder-layout{display:grid;grid-template-columns:minmax(0,1fr) 392px;gap:20px;align-items:start}.recipe-editor,.summary-panel,.workspace-panel{background:#fffdf8f0;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.recipe-editor,.workspace-panel{padding:18px}.summary-panel{position:sticky;top:16px;padding:18px;background:linear-gradient(180deg,#4b2118fa,#32170ffa);color:#fff8ef;border-color:#5d2c20}.summary-panel .empty-state,.summary-panel .error-state{margin-top:16px}.app-message{margin:0 0 14px}.field-label{display:block;margin-bottom:7px;color:var(--color-muted);font-size:12px;font-weight:800}.title-input,.ingredient-form input{width:100%;height:48px;padding:0 13px;color:var(--color-chocolate);background:#fffdf8;border:1px solid #cdb79d;border-radius:var(--radius);font-size:17px;font-weight:700}.title-input{font-family:ui-serif,Georgia,Times New Roman,serif}.ingredient-form input{height:44px;font-size:14px;font-weight:600}.recipe-editor-header,.line-toolbar,.summary-header,.workspace-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.recipe-editor-header{align-items:flex-end}.recipe-editor-header>div:first-child{min-width:240px;flex:1 1 auto}.recipe-command-stack{display:grid;justify-items:end;gap:8px;flex:0 0 auto}.recipe-save-state{min-height:38px;padding:6px 10px;justify-self:end}.recipe-save-state.dirty{color:var(--color-raspberry);background:#fff0f3;border-color:#ecc2cc}.line-toolbar{margin:22px 0 14px}.line-toolbar p,.workspace-header p,.record-row p{margin:5px 0 0;color:var(--color-muted);font-size:13px}.line-toolbar h2,.summary-panel h2,.chart-section h3,.workspace-header h2,.record-row h3,.metric-group h3{margin:0;font-size:18px;line-height:1.2;font-weight:820}.summary-panel h2,.chart-section h3,.metric-group h3{color:#fff8ef}.icon-text-button,.icon-button,.secondary-button,.danger-button,.file-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border-radius:var(--radius);font-size:13px;font-weight:820}.icon-text-button,.icon-button{color:#fffdf8;background:var(--color-pistachio-dark);border:0}.icon-text-button{padding:0 14px;font-size:14px}.icon-button{width:44px;height:44px;padding:0}.secondary-button,.file-button{padding:0 12px;color:var(--color-ganache);background:#fff8ef;border:1px solid var(--color-border)}.danger-button{padding:0 12px;color:#8f1f1f;background:#fff1ef;border:1px solid #ebb6af}.file-button{position:relative;overflow:hidden}.file-button input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.recipe-actions,.row-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.ingredient-lines{display:grid;gap:12px}.ingredient-line{padding:13px;background:linear-gradient(90deg,rgba(201,133,61,.09),transparent 42%),#fffaf2;border:1px solid #e5cfb2;border-radius:var(--radius)}.line-heading{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px}.line-index{display:block;color:var(--color-ganache);font-size:13px;font-weight:840}.line-detail{display:block;margin-top:3px;color:var(--color-muted);font-size:12px}.line-fields{display:grid;grid-template-columns:minmax(0,1fr) 178px;gap:12px}.search-field{position:relative}.search-input-wrap{display:flex;align-items:center;gap:9px;height:46px;padding:0 12px;background:#fffdf8;border:1px solid #cdb79d;border-radius:var(--radius);color:var(--color-copper)}.search-input-wrap input,.quantity-control input{min-width:0;width:100%;height:44px;color:var(--color-chocolate);background:transparent;border:0;outline:0}.search-results{position:absolute;z-index:10;top:calc(100% + 6px);left:0;right:0;max-height:300px;overflow:auto;padding:6px;background:#fffdf8;border:1px solid #cdb79d;border-radius:var(--radius);box-shadow:0 18px 44px #32170f2e}.static-results{position:static;margin-top:8px;box-shadow:none}.search-results button{display:block;width:100%;padding:11px;text-align:left;color:var(--color-chocolate);background:transparent;border:0;border-radius:6px}.search-results button:hover,.search-results button:focus{background:#f5ead9;outline:none}.search-results button>span{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:14px;font-weight:780}.search-results button>small{display:block;margin-top:4px;color:var(--color-muted);font-size:12px}.source-badge{display:inline-flex;align-items:center;min-height:22px;padding:0 7px;border-radius:999px;font-size:11px;line-height:1;font-weight:820}.source-badge.seed{color:var(--color-cocoa);background:#f5e4ca}.source-badge.custom{color:#174b38;background:#dff0e5}.search-results p{margin:8px;color:var(--color-muted);font-size:13px}.quantity-control{display:grid;grid-template-columns:44px minmax(52px,1fr) 44px;gap:6px}.quantity-control input{height:44px;text-align:center;background:#fffdf8;border:1px solid #cdb79d;border-radius:var(--radius);font-variant-numeric:tabular-nums;font-weight:820}.quantity-quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-top:7px}.quick-step-button{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:44px;padding:0 6px;color:var(--color-ganache);background:#f7ead7;border:1px solid #e1cdb4;border-radius:6px;font-size:12px;font-weight:820}.quick-step-button.clear{color:#7f1d1d;background:#fff2ee}.line-calculation{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}.line-calculation span,.flag-pill{display:inline-flex;align-items:center;gap:5px;min-height:30px;padding:0 9px;border-radius:999px;font-size:12px;font-weight:820}.line-calculation span{color:var(--color-ganache);background:#f4dfc2}.summary-header strong{font-variant-numeric:tabular-nums;font-size:28px;line-height:1;color:#f5c06d}.empty-state,.error-state,.success-state{margin-top:18px;padding:16px;border-radius:var(--radius);font-size:14px}.empty-state{color:var(--color-muted);background:#f4ebdc}.error-state{color:#7f1d1d;background:#fff1ef}.success-state{color:#174b38;background:#eaf7ed}.compact{margin-top:10px;padding:10px 12px}.flag-row{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}.flag-pill{color:#eadac4;background:#fff8ef1f;border:1px solid rgba(255,248,239,.18)}.flag-pill.compatible.active{color:#dbffe9;background:#4f7f646b}.flag-pill.allergen.active{color:#ffe7ee;background:#a73d5673}.metrics-groups{display:grid;gap:13px}.metric-group{display:grid;gap:8px}.metric-group h3{font-size:13px;color:#f2d7b2;letter-spacing:0}.metrics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.metric-tile{min-width:0;padding:10px;background:#fff8ef1a;border:1px solid rgba(255,248,239,.16);border-radius:7px}.metric-tile span{display:block;color:#e5c9a6;font-size:12px;font-weight:760}.metric-tile strong{display:block;margin-top:5px;color:#fff8ef;font-variant-numeric:tabular-nums;font-size:17px;line-height:1.1}.chart-section{margin-top:20px}.chart-frame{width:100%;height:260px;margin-top:10px}.chart-frame text{fill:#f0dcc2}.chart-frame .recharts-cartesian-grid line{stroke:#fff8ef29}.workspace-grid{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:20px;align-items:start}.workspace-header{align-items:flex-start;margin-bottom:16px}.record-list{display:grid;gap:10px}.record-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:13px;background:#fffaf2;border:1px solid #e5cfb2;border-radius:var(--radius)}.compact-row{grid-template-columns:1fr}.duplicate-search{margin-bottom:16px}.ingredient-form{display:grid;gap:16px}.form-grid,.metric-form-grid{display:grid;gap:10px}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.metric-form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.flag-editor{display:flex;flex-wrap:wrap;gap:8px}.flag-editor label{display:inline-flex;align-items:center;gap:7px;min-height:38px;padding:0 10px;color:var(--color-ganache);background:#f4ebdc;border-radius:999px;font-size:13px;font-weight:760}.flag-editor input{width:18px;height:18px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:18px;background:#32170f5c}.confirm-dialog{width:min(420px,100%);display:grid;grid-template-columns:44px minmax(0,1fr);gap:12px;padding:18px;color:var(--color-chocolate);background:#fffdf8;border:1px solid #d8bea0;border-radius:var(--radius);box-shadow:0 22px 70px #32170f47}.dialog-icon{display:grid;place-items:center;width:44px;height:44px;color:#8f1f1f;background:#fff1ef;border-radius:var(--radius)}.confirm-dialog h2{margin:0;font-size:18px;line-height:1.2}.confirm-dialog p{margin:7px 0 0;color:var(--color-muted);font-size:14px;line-height:1.45}.dialog-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:8px;margin-top:4px}@media(max-width:860px){.app-shell{padding:14px}.app-header{align-items:flex-start;flex-direction:column}.app-header h1{font-size:25px}.header-status{width:100%;justify-content:flex-start}.builder-layout,.workspace-grid{grid-template-columns:1fr}.summary-panel{position:static}}@media(max-width:560px){.app-shell{padding:12px}.brand-mark{width:46px;height:46px}.app-header p{font-size:13px}.offline-status,.ingredient-count{flex:1 1 150px}.recipe-editor,.summary-panel,.workspace-panel{padding:13px}.recipe-editor-header,.workspace-header,.record-row{align-items:stretch;grid-template-columns:1fr}.recipe-editor-header,.workspace-header{flex-direction:column}.recipe-command-stack,.recipe-save-state{justify-items:stretch;width:100%}.recipe-actions,.row-actions,.dialog-actions{justify-content:stretch}.recipe-actions>*,.row-actions>*,.dialog-actions>*{flex:1 1 auto}.line-fields{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ingredient-line{padding:11px}.form-grid.two,.metric-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.confirm-dialog{grid-template-columns:1fr}}
