@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-vietnamese-400-normal-CYVZRxRj.woff2) format("woff2"),url(/assets/quicksand-vietnamese-400-normal-D4WCpyCa.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-latin-ext-400-normal-BdPaGDPN.woff2) format("woff2"),url(/assets/quicksand-latin-ext-400-normal-BzqwlOho.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-latin-400-normal-BSDtH9U0.woff2) format("woff2"),url(/assets/quicksand-latin-400-normal-BqXBKzPR.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-vietnamese-500-normal-CMA0PiFa.woff2) format("woff2"),url(/assets/quicksand-vietnamese-500-normal-DdPH4leT.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-latin-ext-500-normal-Rkq3IeWS.woff2) format("woff2"),url(/assets/quicksand-latin-ext-500-normal-BlYHgpcu.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-latin-500-normal-_DbwbYKP.woff2) format("woff2"),url(/assets/quicksand-latin-500-normal-7J1fbcAD.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-vietnamese-600-normal-dD2kotB2.woff2) format("woff2"),url(/assets/quicksand-vietnamese-600-normal-JmvBH-hY.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-latin-ext-600-normal-fxOF3zcr.woff2) format("woff2"),url(/assets/quicksand-latin-ext-600-normal-BDPVAPCS.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-latin-600-normal-DTBPeRoM.woff2) format("woff2"),url(/assets/quicksand-latin-600-normal-CkxN0sDw.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/quicksand-vietnamese-700-normal-5oDqeHTF.woff2) format("woff2"),url(/assets/quicksand-vietnamese-700-normal-BsIWXrxI.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/quicksand-latin-ext-700-normal-8b1JBoEj.woff2) format("woff2"),url(/assets/quicksand-latin-ext-700-normal-DbLsDSEV.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/quicksand-latin-700-normal-Dpk7G9Y6.woff2) format("woff2"),url(/assets/quicksand-latin-700-normal-HjJN-aaT.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/playfair-display-cyrillic-600-normal-oLY6jnZ7.woff2) format("woff2"),url(/assets/playfair-display-cyrillic-600-normal-DbWAkkgN.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/playfair-display-vietnamese-600-normal-ICsRR-qJ.woff2) format("woff2"),url(/assets/playfair-display-vietnamese-600-normal-BPJkAZPN.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/playfair-display-latin-ext-600-normal-CEjQclLc.woff2) format("woff2"),url(/assets/playfair-display-latin-ext-600-normal-BumBfC1v.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/playfair-display-latin-600-normal-CZLGqjJe.woff2) format("woff2"),url(/assets/playfair-display-latin-600-normal-CxxueQ0Z.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/playfair-display-cyrillic-700-normal-Dw3uKy19.woff2) format("woff2"),url(/assets/playfair-display-cyrillic-700-normal-Dk1mTcxf.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/playfair-display-vietnamese-700-normal-CaKJSIny.woff2) format("woff2"),url(/assets/playfair-display-vietnamese-700-normal-Cr1rw0mr.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/playfair-display-latin-ext-700-normal-C58ejOkc.woff2) format("woff2"),url(/assets/playfair-display-latin-ext-700-normal-D5HUU8GT.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/playfair-display-latin-700-normal-CuDiGg7c.woff2) format("woff2"),url(/assets/playfair-display-latin-700-normal-Bc_1Q1cG.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/playfair-display-cyrillic-800-normal-BNMG-Q7a.woff2) format("woff2"),url(/assets/playfair-display-cyrillic-800-normal-Drcgs-AM.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/playfair-display-vietnamese-800-normal-eAF99_Jc.woff2) format("woff2"),url(/assets/playfair-display-vietnamese-800-normal-DQKEhsq9.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/playfair-display-latin-ext-800-normal-ZgHWgVpM.woff2) format("woff2"),url(/assets/playfair-display-latin-ext-800-normal-DD7uHqs8.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/playfair-display-latin-800-normal-lwhkvH_6.woff2) format("woff2"),url(/assets/playfair-display-latin-800-normal-D0Xz4t1K.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--brand: #6e1a2b;--brand-dark: #4f0f19;--brand-light: #f3e1e6;--accent: #e985b4;--sage: #c7cbbb;--pink: #e985b4;--bg: #f5efe4;--card: #fffdf9;--ink: #2b221e;--muted: #8c8076;--line: #e8e0d2;--good: #2e7d4f;--good-bg: #ddefe2;--bad: #b23a3a;--bad-bg: #f6e0de;--warn: #b07a1e;--warn-bg: #f6ebd4;--radius: 16px;--shadow: 0 1px 3px rgba(43, 34, 30, .08), 0 1px 2px rgba(43, 34, 30, .05);--shadow-lg: 0 10px 30px rgba(78, 16, 25, .14);--font-title: "Playfair Display", Georgia, "Times New Roman", serif;--font-body: "Quicksand", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:15px}.topbar-title,.section-title h2,.sheet-header h3,.empty-title,h1,h2,h3{font-family:var(--font-title);letter-spacing:0}input,select,button,textarea{font-family:inherit;font-size:16px}.app{min-height:100%;display:flex;flex-direction:column;max-width:560px;margin:0 auto;background:var(--bg)}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;padding-top:max(14px,env(safe-area-inset-top));background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;box-shadow:var(--shadow)}.topbar-title{display:flex;align-items:center;gap:9px;font-weight:700;font-size:17px;cursor:pointer}.topbar-logo{font-size:20px}.topbar-logo-img{width:34px;height:34px;border-radius:50%;object-fit:cover;background:var(--card);border:1.5px solid rgba(255,255,255,.5)}.topbar-actions{display:flex;align-items:center;gap:10px}.mode-badge{font-size:11px;font-weight:600;padding:4px 8px;border-radius:999px;background:#fff3}.icon-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:10px;font-size:18px;cursor:pointer}.content{flex:1;padding:16px 16px 96px}.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center;color:var(--muted)}.spinner{width:36px;height:36px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.bottomnav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:560px;display:grid;grid-template-columns:repeat(5,1fr);background:var(--card);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom);z-index:20}.navitem{display:flex;flex-direction:column;align-items:center;gap:2px;padding:9px 0 7px;color:var(--muted);text-decoration:none;font-size:11px;font-weight:600}.navitem.active{color:var(--brand)}.navicon{font-size:20px;filter:grayscale(.4)}.navitem.active .navicon{filter:none}.section-title{display:flex;align-items:center;justify-content:space-between;margin:22px 2px 12px}.section-title:first-child{margin-top:4px}.section-title h2{font-size:16px;font-weight:700}.card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);margin-bottom:12px}.card-clickable{cursor:pointer;transition:transform .06s}.card-clickable:active{transform:scale(.99)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.stat{background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);border-left:4px solid var(--brand)}.stat-label{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:5px}.stat-icon{font-size:14px}.stat-value{font-size:22px;font-weight:800;margin-top:4px;letter-spacing:-.5px}.stat-sub{font-size:11px;color:var(--muted);margin-top:2px}.stat-good{border-left-color:var(--good)}.stat-good .stat-value{color:var(--good)}.stat-bad{border-left-color:var(--bad)}.stat-bad .stat-value{color:var(--bad)}.stat-warn{border-left-color:var(--warn)}.stat-brand{border-left-color:var(--brand);background:linear-gradient(135deg,#fff,var(--brand-light))}.hero{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;border-radius:20px;padding:20px;box-shadow:var(--shadow-lg);margin-bottom:14px}.hero-label{font-size:13px;opacity:.9;font-weight:600}.hero-value{font-size:34px;font-weight:800;margin:4px 0;letter-spacing:-1px}.hero-row{display:flex;gap:18px;margin-top:10px}.hero-item{font-size:12px;opacity:.95}.hero-item b{display:block;font-size:16px;font-weight:700}.btn{border:none;border-radius:12px;padding:12px 16px;font-weight:700;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:opacity .1s,transform .06s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff}.btn-danger{background:var(--bad);color:#fff}.btn-soft{background:var(--brand-light);color:var(--brand-dark)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}.btn-full{width:100%}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px}.quick-btn{background:var(--card);border:none;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:flex-start;gap:6px;cursor:pointer;text-align:left}.quick-btn:active{transform:scale(.98)}.quick-btn .qa-icon{font-size:24px}.quick-btn .qa-label{font-weight:700;font-size:14px}.quick-btn .qa-sub{font-size:11px;color:var(--muted)}.row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}.row:last-child{border-bottom:none}.row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.row-title{font-weight:600;font-size:14px}.row-sub{font-size:12px;color:var(--muted)}.row-right{text-align:right;white-space:nowrap}.row-amount{font-weight:700}.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--line);color:var(--muted)}.pill-good{background:var(--good-bg);color:var(--good)}.pill-bad{background:var(--bad-bg);color:var(--bad)}.pill-warn{background:var(--warn-bg);color:var(--warn)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field-label{font-size:13px;font-weight:600;color:var(--ink)}.field-hint{font-size:11px;color:var(--muted)}.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:50;display:flex;align-items:flex-end;justify-content:center}.sheet{background:var(--card);width:100%;max-width:560px;border-radius:22px 22px 0 0;max-height:92vh;display:flex;flex-direction:column;animation:slideup .22s ease}@keyframes slideup{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 10px;border-bottom:1px solid var(--line)}.sheet-header h3{font-size:17px;font-weight:700}.sheet-close{background:var(--bg);border:none;width:32px;height:32px;border-radius:50%;font-size:22px;line-height:1;cursor:pointer;color:var(--muted)}.sheet-body{padding:18px;overflow-y:auto}.sheet-footer{padding:14px 18px;padding-bottom:max(14px,env(safe-area-inset-bottom));border-top:1px solid var(--line);display:flex;gap:10px}.empty{text-align:center;padding:40px 20px;color:var(--muted)}.empty-icon{font-size:44px;margin-bottom:10px}.empty-title{font-weight:700;color:var(--ink);margin-bottom:4px}.empty-sub{font-size:13px}.tabs{display:flex;gap:6px;background:var(--card);padding:5px;border-radius:12px;box-shadow:var(--shadow);margin-bottom:14px}.tab{flex:1;text-align:center;padding:9px;border-radius:9px;font-weight:600;font-size:13px;color:var(--muted);border:none;background:transparent;cursor:pointer}.tab.active{background:var(--brand);color:#fff}.toasts{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:60;width:calc(100% - 32px);max-width:528px}.toast{padding:12px 16px;border-radius:12px;font-weight:600;font-size:13px;box-shadow:var(--shadow-lg);animation:slideup .2s ease}.toast-ok{background:var(--good);color:#fff}.toast-error{background:var(--bad);color:#fff}.muted{color:var(--muted)}.text-good{color:var(--good)}.text-bad{color:var(--bad)}.text-warn{color:var(--warn)}.mini{font-size:12px}.spacer{height:8px}.center{text-align:center}.cart-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.cart-item-main{flex:1;min-width:0}.qty-control{display:flex;align-items:center;gap:10px}.qty-btn{width:34px;height:34px;border-radius:9px;border:1.5px solid var(--line);background:#fff;font-size:20px;font-weight:700;cursor:pointer;color:var(--brand-dark);display:flex;align-items:center;justify-content:center}.qty-num{min-width:24px;text-align:center;font-weight:700;font-size:16px}.chips{display:grid;grid-template-columns:1fr 1fr;gap:10px}.chip{padding:14px 12px;border-radius:14px;border:1.5px solid var(--line);background:#fff;cursor:pointer;text-align:left;transition:transform .06s}.chip:active{transform:scale(.97)}.chip-active{border-color:var(--brand);background:var(--brand-light);box-shadow:0 0 0 1.5px var(--brand) inset}.chip-name{font-weight:700;font-size:14px}.chip-price{color:var(--brand-dark);font-weight:700;font-size:13px;margin-top:2px}.chip-stock{font-size:11px;color:var(--muted);margin-top:2px}.bar-row{display:flex;align-items:center;gap:8px;margin:8px 0}.bar-label{width:92px;font-size:12px;font-weight:600;flex-shrink:0}.bar-track{flex:1;background:var(--bg);border-radius:999px;height:22px;overflow:hidden;position:relative}.bar-fill{height:100%;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:999px;min-width:2px}.bar-val{font-size:12px;font-weight:700;width:64px;text-align:right;flex-shrink:0}.recipe-line{display:grid;grid-template-columns:1fr 86px 36px;gap:8px;align-items:center;margin-bottom:8px}.recipe-line select,.recipe-line input{padding:10px;border:1.5px solid var(--line);border-radius:10px}.link-btn{background:none;border:none;color:var(--brand);font-weight:600;cursor:pointer;padding:0;font-size:14px}.list-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:4px 16px;margin-bottom:12px}.merma-btn{width:100%;background:transparent;border:1.5px dashed var(--line);color:var(--muted);border-radius:12px;padding:12px;font-weight:600;font-size:14px;cursor:pointer;margin-top:4px}.merma-btn:active{transform:scale(.99)}.salida-line{display:grid;grid-template-columns:1fr 70px 70px;gap:8px;align-items:center;margin-bottom:8px}.salida-name{display:flex;flex-direction:column;gap:1px;min-width:0}.salida-line input{padding:10px;border:1.5px solid var(--line);border-radius:10px;width:100%;text-align:center}.salida-line input:focus{border-color:var(--brand);outline:none}.info-banner{background:var(--brand-light);color:var(--brand-dark);border-radius:12px;padding:12px 14px;font-size:13px;margin-bottom:14px;line-height:1.4}.warn-banner{background:var(--warn-bg);color:var(--warn);border-radius:12px;padding:12px 14px;font-size:13px;margin-bottom:14px}.rec-card{display:flex;gap:12px;align-items:flex-start}.rec-icon{font-size:24px}.rec-title{font-weight:700;font-size:14px}.rec-detail{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.4}@media (min-width: 900px){.app{max-width:1120px;display:grid;grid-template-columns:232px 1fr;grid-template-rows:auto 1fr;grid-template-areas:"top  top" "side main";min-height:100vh}.topbar{grid-area:top;position:static;padding:16px 28px}.topbar-title{font-size:20px}.topbar-logo-img{width:40px;height:40px}.bottomnav{grid-area:side;position:static;transform:none;width:auto;max-width:none;display:flex;flex-direction:column;gap:4px;border-top:none;border-right:1px solid var(--line);background:var(--card);padding:18px 14px;align-items:stretch}.navitem{flex-direction:row;justify-content:flex-start;gap:12px;padding:13px 16px;border-radius:12px}.navitem.active{background:var(--brand-light)}.navicon{font-size:22px;filter:none}.navlabel{font-size:14.5px}.content{grid-area:main;padding:26px 32px 48px}.toasts{left:auto;right:28px;transform:none;max-width:380px;width:auto;bottom:24px}.stat-grid{grid-template-columns:repeat(4,1fr)}.stat-grid-3{grid-template-columns:repeat(3,1fr)}.quick-actions{grid-template-columns:repeat(4,1fr)}.chips{grid-template-columns:repeat(3,1fr)}.section-title h2{font-size:19px}.hero{padding:24px 28px}.hero-value{font-size:40px}.sheet-backdrop{align-items:center}.sheet{max-width:560px;border-radius:22px;max-height:86vh}.sheet{animation:popin .18s ease}@keyframes popin{0%{transform:scale(.96);opacity:.6}to{transform:scale(1);opacity:1}}}@media (min-width: 1280px){.app{max-width:1240px}}
