:root{--m-bottom-nav-h: 64px;--m-header-h: 56px;--m-safe-bottom: env(safe-area-inset-bottom, 0px);--m-safe-top: env(safe-area-inset-top, 0px)}.m-app{min-height:100vh;min-height:100dvh;background:var(--bg, #f6f7f9);color:var(--text, #1a1f29);font-family:Nunito Sans,system-ui,-apple-system,sans-serif;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}.m-app *{box-sizing:border-box}.m-header{position:sticky;top:0;z-index:50;height:calc(var(--m-header-h) + var(--m-safe-top));padding-top:var(--m-safe-top);padding-inline:16px;background:var(--surface, #fff);border-bottom:1px solid var(--border, #e5e7eb);display:flex;align-items:center;gap:12px}.m-header__title{flex:1;font-weight:800;font-size:17px;letter-spacing:-.01em;color:var(--text, #1a1f29);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-header__btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--border, #e5e7eb);background:transparent;color:var(--text, #1a1f29);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.m-header__btn:active{background:var(--s2, #f1f3f5)}.m-page{min-height:calc(100dvh - var(--m-bottom-nav-h) - var(--m-header-h) - var(--m-safe-top) - var(--m-safe-bottom));padding:12px 16px calc(16px + var(--m-bottom-nav-h) + var(--m-safe-bottom))}.m-page--no-tabs{padding-bottom:calc(16px + var(--m-safe-bottom))}.m-tabs{position:fixed;bottom:0;left:0;right:0;height:calc(var(--m-bottom-nav-h) + var(--m-safe-bottom));padding-bottom:var(--m-safe-bottom);background:var(--surface, #fff);border-top:1px solid var(--border, #e5e7eb);display:grid;grid-template-columns:repeat(5,1fr);z-index:40}.m-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--muted, #6b7280);font-family:inherit;font-size:10.5px;font-weight:600;cursor:pointer;padding:6px 4px;position:relative;transition:color .15s}.m-tab__icon{font-size:22px;line-height:1}.m-tab__label{letter-spacing:.01em}.m-tab--active{color:var(--c-boq, #1a6b3a)}.m-tab--active .m-tab__icon{transform:translateY(-1px)}.m-tab__badge{position:absolute;top:4px;right:calc(50% - 18px);min-width:16px;height:16px;padding:0 4px;background:#dc2626;color:#fff;border-radius:8px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.m-card{background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:14px;padding:14px;margin-bottom:10px}.m-card__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted, #6b7280);margin-bottom:8px}.m-stat{display:flex;align-items:center;gap:12px;padding:14px;background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:14px;cursor:pointer;transition:transform .12s,box-shadow .12s;width:100%;text-align:left;font-family:inherit;color:var(--text, #1a1f29)}.m-stat:active{transform:scale(.98)}.m-stat__icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.m-stat__body{flex:1;min-width:0}.m-stat__label{font-size:13px;font-weight:600;color:var(--text, #1a1f29);margin-bottom:2px}.m-stat__count{font-size:11px;color:var(--muted, #6b7280)}.m-stat__chev{color:var(--muted, #c1c7d0);font-size:18px;flex-shrink:0}.m-input{width:100%;height:48px;padding:0 14px;border:1px solid var(--border, #e5e7eb);border-radius:12px;background:var(--surface, #fff);font-size:16px;font-family:inherit;color:var(--text, #1a1f29);outline:none;transition:border-color .15s,box-shadow .15s}.m-input:focus{border-color:var(--c-boq, #1a6b3a);box-shadow:0 0 0 3px #1a6b3a1f}.m-input::placeholder{color:var(--muted, #9ca3af)}.m-label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted, #6b7280);margin-bottom:6px}.m-btn{width:100%;height:50px;border:none;border-radius:12px;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s,transform .12s}.m-btn:active:not(:disabled){transform:scale(.98)}.m-btn:disabled{opacity:.55;cursor:not-allowed}.m-btn--primary{background:var(--c-boq, #1a6b3a);color:#fff}.m-btn--ghost{background:transparent;border:1px solid var(--border, #e5e7eb);color:var(--text, #1a1f29)}.m-btn--danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.m-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:100;display:flex;align-items:flex-end;animation:m-fade-in .2s ease-out}.m-sheet{width:100%;background:var(--surface, #fff);border-radius:20px 20px 0 0;padding:12px 16px calc(16px + var(--m-safe-bottom));animation:m-slide-up .25s cubic-bezier(.2,.9,.3,1);max-height:80vh;overflow-y:auto}.m-sheet__handle{width:38px;height:4px;background:var(--border2, #e5e7eb);border-radius:2px;margin:4px auto 12px}.m-sheet__title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted, #6b7280);padding:0 4px 8px}.m-sheet__row{display:flex;align-items:center;gap:12px;padding:14px 8px;width:100%;background:none;border:none;font-family:inherit;font-size:15px;color:var(--text, #1a1f29);cursor:pointer;text-align:left;border-bottom:1px solid var(--border2, #f1f3f5)}.m-sheet__row:last-child{border-bottom:none}.m-sheet__row:active{background:var(--s2, #f1f3f5)}.m-sheet__row--danger{color:#dc2626}.m-sheet__row__icon{font-size:20px;width:24px;text-align:center}.m-sheet__row__label{flex:1}.m-sheet__row__hint{font-size:11px;color:var(--muted, #9ca3af)}.m-empty{text-align:center;padding:48px 24px;color:var(--muted, #6b7280)}.m-empty__icon{font-size:48px;opacity:.4;margin-bottom:12px}.m-empty__title{font-size:15px;font-weight:600;color:var(--text, #1a1f29);margin-bottom:4px}.m-empty__hint{font-size:13px;line-height:1.5}.m-loading{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;padding:80px 24px;color:var(--muted, #6b7280);font-size:13px}.m-spinner{width:36px;height:36px;border:3px solid var(--border2, #e5e7eb);border-top-color:var(--c-boq, #1a6b3a);border-radius:50%;animation:m-spin .85s linear infinite}.m-toast{position:fixed;left:16px;right:16px;bottom:calc(var(--m-bottom-nav-h) + var(--m-safe-bottom) + 12px);background:#1a1f29;color:#fff;padding:12px 16px;border-radius:12px;font-size:13px;font-weight:500;z-index:200;box-shadow:0 8px 24px #00000040;animation:m-slide-up .25s cubic-bezier(.2,.9,.3,1)}.m-toast--error{background:#dc2626}.m-toast--success{background:#1a6b3a}@keyframes m-fade-in{0%{opacity:0}to{opacity:1}}@keyframes m-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes m-spin{to{transform:rotate(360deg)}}.m-app *:focus-visible{outline:2px solid var(--c-boq, #1a6b3a);outline-offset:2px;border-radius:8px}
