@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--font:"Inter", system-ui, -apple-system, sans-serif;--mono:ui-monospace, "SF Mono", "Fira Code", monospace;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--border-2:#cbd5e1;--txt:#0f172a;--txt-2:#64748b;--txt-3:#94a3b8;--blue:#2563eb;--blue-hover:#1d4ed8;--blue-bg:#eff6ff;--blue-border:#bfdbfe;--green:#15803d;--green-hover:#166534;--green-bg:#f0fdf4;--green-border:#bbf7d0;--green-txt:#16a34a;--red:#dc2626;--red-hover:#b91c1c;--red-bg:#fef2f2;--red-border:#fecaca;--amber-bg:#fffbeb;--amber-border:#fde68a;--amber-txt:#92400e;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -2px #00000014;--r-sm:6px;--r:10px;--r-lg:14px;--surface-1:#f8fafc;--surface-2:#f1f5f9;--txt-1:#0f172a;--accent-green:#15803d;--pattern-dot:#94a3b8;--pattern-active:#2563eb;--pattern-line:#2563eb;--pattern-error:#dc2626;--txt-secondary:var(--txt-2);--danger:var(--red);--warn:var(--amber-txt);--accent:var(--blue);--bg-2:var(--surface-2)}html.dark{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0f172a;--surface:#1e293b;--border:#334155;--border-2:#475569;--txt:#f1f5f9;--txt-2:#94a3b8;--txt-3:#64748b;--blue:#60a5fa;--blue-hover:#93c5fd;--blue-bg:#3b82f61f;--blue-border:#3b82f64d;--green:#22c55e;--green-hover:#16a34a;--green-bg:#16a34a1f;--green-border:#16a34a4d;--green-txt:#4ade80;--red:#f87171;--red-hover:#fca5a5;--red-bg:#dc26261f;--red-border:#dc26264d;--amber-bg:#f59e0b1a;--amber-border:#f59e0b40;--amber-txt:#fbbf24;--shadow-xs:0 1px 2px 0 #0003;--shadow-sm:0 1px 3px 0 #0000004d, 0 1px 2px -1px #0000004d;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0000004d;--surface-1:#1e293b;--surface-2:#253344;--txt-1:#f1f5f9;--accent-green:#4ade80;--pattern-dot:#64748b;--pattern-active:#60a5fa;--pattern-line:#60a5fa;--pattern-error:#f87171}*,:before,:after{box-sizing:border-box}html{font-family:var(--font);color:var(--txt);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-size:16px;line-height:1.5}body{margin:0}h1,h2,h3{color:var(--txt);margin:0;font-weight:700;line-height:1.2}p{margin:0}#root{min-height:100svh;padding-bottom:80px}.top-bar{z-index:50;background:var(--surface);border-bottom:1px solid var(--border);height:52px;box-shadow:var(--shadow-xs);justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.top-bar__user{color:var(--txt-2);font-size:13px;font-weight:500}.top-bar__logout{border:1px solid var(--border);color:var(--txt-2);border-radius:var(--r-sm);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:5px 12px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex}.top-bar__logout:hover{background:var(--bg);border-color:var(--border-2);color:var(--txt)}.top-bar__theme{border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;width:34px;height:34px;color:var(--txt-2);background:0 0;justify-content:center;align-items:center;font-size:16px;line-height:1;transition:background .15s,color .15s,border-color .15s;display:flex}.top-bar__theme:hover{background:var(--bg);border-color:var(--border-2);color:var(--txt)}.top-bar__right{align-items:center;gap:8px;display:flex}.bottom-nav{z-index:100;background:var(--surface);border-top:1px solid var(--border);padding:6px 8px;padding-bottom:max(6px, env(safe-area-inset-bottom));justify-content:center;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 16px #0000000f}html.dark .bottom-nav{box-shadow:0 -2px 16px #00000040}.mobile-nav{z-index:100;background:var(--surface);border-top:1px solid var(--border);padding:6px 4px;padding-bottom:max(6px, env(safe-area-inset-bottom));justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 16px #0000000f}html.dark .mobile-nav{box-shadow:0 -2px 16px #00000040}.mobile-nav .nav-tab{min-width:0;font:inherit;cursor:pointer;background:0 0;border:none;flex:1;padding:6px 4px}.mobile-nav .nav-tab__label{display:block}.mobile-drawer-overlay{z-index:290;opacity:0;visibility:hidden;background:#0006;transition:opacity .2s,visibility .2s;position:fixed;inset:0}.mobile-drawer-overlay--open{opacity:1;visibility:visible}.mobile-drawer{z-index:300;background:var(--surface);border-right:1px solid var(--border);width:78vw;max-width:300px;padding-bottom:env(safe-area-inset-bottom);flex-direction:column;transition:transform .22s;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0000002e}.mobile-drawer--open{transform:translate(0)}.mobile-drawer__header{border-bottom:1px solid var(--border);padding:16px 18px;padding-top:max(16px, env(safe-area-inset-top));justify-content:space-between;align-items:center;display:flex}.mobile-drawer__title{color:var(--txt-1);font-size:17px;font-weight:700}.mobile-drawer__close{color:var(--txt-3);cursor:pointer;border-radius:var(--r);background:0 0;border:none;padding:6px 8px;font-size:18px;line-height:1}.mobile-drawer__close:hover{background:var(--bg);color:var(--txt-1)}.mobile-drawer__links{flex-direction:column;gap:2px;padding:10px;display:flex;overflow-y:auto}.drawer-link{color:var(--txt-2);border-radius:var(--r);-webkit-tap-highlight-color:transparent;align-items:center;gap:14px;padding:12px 14px;text-decoration:none;display:flex}.drawer-link:hover{background:var(--bg)}.drawer-link__icon{text-align:center;flex-shrink:0;width:28px;font-size:18px;font-weight:700}.drawer-link__label{font-size:15px;font-weight:600}.drawer-link--active{background:var(--blue-bg);color:var(--blue)}.nav-tab{min-width:60px;color:var(--txt-3);border-radius:var(--r);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:3px;padding:6px 20px;text-decoration:none;transition:color .15s,background .15s;display:flex}.nav-tab:hover{background:var(--bg);color:var(--txt-2)}.nav-tab__icon{border-radius:8px;justify-content:center;align-items:center;width:32px;height:28px;font-size:18px;font-weight:700;line-height:1;transition:background .15s;display:flex}.nav-tab__label{letter-spacing:.02em;text-transform:uppercase;font-size:10px;font-weight:500}.nav-tab--active .nav-tab__icon{background:var(--blue-bg)}.nav-tab--active .nav-tab__label{font-weight:700}.page{width:100%;max-width:560px;margin:0 auto;padding:20px 16px}.page__title{letter-spacing:-.02em;color:var(--txt);align-items:center;gap:10px;margin:0 0 20px;font-size:22px;font-weight:800;display:flex}.page__title:before{content:"";background:var(--grad);border-radius:3px;flex-shrink:0;width:4px;height:22px;display:block}.page__title--green{color:var(--green-txt)}.page__title--green:before{background:var(--green-txt)}.page__title--red{color:var(--red)}.page__title--red:before{background:var(--red)}.page__title--blue{color:var(--blue)}.page__title--blue:before{background:var(--blue)}.page__title--plain:before{display:none}.alert{border-radius:var(--r);border:1px solid;align-items:flex-start;gap:10px;margin-bottom:14px;padding:12px 14px;font-size:14px;line-height:1.4;display:flex}.alert--error{color:var(--red);background:var(--red-bg);border-color:var(--red-border)}.alert--success{color:var(--green-txt);background:var(--green-bg);border-color:var(--green-border)}.alert--warning{color:var(--amber-txt);background:var(--amber-bg);border-color:var(--amber-border)}.scan-form{gap:8px;margin-bottom:16px;display:flex}.scan-form__input{min-width:0;height:48px;font-size:15px;font-family:var(--font);border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);color:var(--txt);outline:none;flex:1;padding:0 14px;transition:border-color .15s,box-shadow .15s}.scan-form__input::placeholder{color:var(--txt-3)}.scan-form__input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.scan-form__btn{border-radius:var(--r);color:#fff;cursor:pointer;height:48px;font-size:14px;font-weight:600;font-family:var(--font);white-space:nowrap;box-shadow:var(--shadow-sm);border:none;padding:0 20px;transition:background .15s,transform .1s,box-shadow .15s}.scan-form__btn:active{transform:scale(.97)}.scan-form__btn--green{background:var(--green)}.scan-form__btn--green:hover{background:var(--green-hover)}.scan-form__btn--red{background:var(--red)}.scan-form__btn--red:hover{background:var(--red-hover)}.scan-form__btn--blue{background:var(--blue)}.scan-form__btn--blue:hover{background:var(--blue-hover)}.product-card{border-radius:var(--r-lg);border:1.5px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);padding:18px}.product-card--green{border-color:var(--green-border);background:var(--green-bg)}.product-card--red{border-color:var(--red-border);background:var(--red-bg)}.product-card--blue{border-color:var(--blue-border);background:var(--blue-bg)}.product-card__header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.product-card__name{color:var(--txt);flex:1;font-size:17px;font-weight:700;line-height:1.3}.product-card__edit-btn{border:1px solid var(--border-2);cursor:pointer;font-size:12px;font-family:var(--font);color:var(--txt-2);border-radius:var(--r-sm);white-space:nowrap;background:0 0;padding:3px 10px;font-weight:500;transition:background .15s,color .15s}.product-card__edit-btn:hover{background:var(--bg);color:var(--txt)}.product-card__badge{border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.product-card__badge--edit{background:var(--warn-bg,#ffa5001f);color:var(--warn,#b45309);border:1px solid var(--warn-border,#ffa5004d)}.product-card__source{color:var(--txt-3);letter-spacing:.02em;text-transform:uppercase;margin-bottom:10px;font-size:11px;font-weight:500}.product-card__details{border-radius:var(--r-sm);background:#00000008;flex-direction:column;gap:8px;margin-bottom:2px;padding:12px;display:flex}.product-card__row{justify-content:space-between;align-items:center;font-size:13px;display:flex}.product-card__label{color:var(--txt-2);font-weight:500}.product-card__value{color:var(--txt);font-family:var(--mono);font-size:13px;font-weight:500}.product-card__value--bold{font-size:20px;font-weight:700;font-family:var(--font)}.product-card__cancel{border:1.5px solid var(--border);border-radius:var(--r);width:100%;color:var(--txt-2);font-size:14px;font-family:var(--font);cursor:pointer;background:0 0;margin-top:10px;padding:9px;font-weight:500;transition:background .15s,color .15s;display:block}.product-card__cancel:hover{background:var(--bg);color:var(--txt)}.confirm-block{border-top:1px solid var(--border);background:inherit;z-index:10;align-items:center;gap:10px;margin-top:16px;padding-top:16px;display:flex;position:sticky;bottom:76px}.confirm-block__label{color:var(--txt-2);white-space:nowrap;font-size:13px;font-weight:500}.confirm-block__qty{text-align:center;border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);width:68px;height:44px;color:var(--txt);font-size:20px;font-weight:700;font-family:var(--font);-moz-appearance:textfield;outline:none;padding:0 4px;transition:border-color .15s,box-shadow .15s}.confirm-block__qty::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.confirm-block__qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.confirm-block__qty:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.confirm-block__price{border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);width:90px;height:44px;color:var(--txt);font-size:14px;font-family:var(--font);-moz-appearance:textfield;outline:none;padding:0 10px;transition:border-color .15s,box-shadow .15s}.confirm-block__price::placeholder{color:var(--txt-3);font-size:12px}.confirm-block__price::-webkit-outer-spin-button{-webkit-appearance:none}.confirm-block__price::-webkit-inner-spin-button{-webkit-appearance:none}.confirm-block__price:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.confirm-block__btn{border-radius:var(--r);color:#fff;height:44px;font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;box-shadow:var(--shadow-sm);border:none;flex:1;padding:0 16px;transition:background .15s,transform .1s,opacity .15s}.confirm-block__btn:active{transform:scale(.97)}.confirm-block__btn:disabled{opacity:.45;cursor:default;transform:none}.confirm-block__btn--green{background:var(--green)}.confirm-block__btn--green:hover:not(:disabled){background:var(--green-hover)}.confirm-block__btn--red{background:var(--red)}.confirm-block__btn--red:hover:not(:disabled){background:var(--red-hover)}.confirm-block__btn--blue{background:var(--blue)}.confirm-block__btn--blue:hover:not(:disabled){background:var(--blue-hover)}.name-form{gap:8px;margin-top:12px;display:flex}.name-form__input{border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--surface);min-width:0;height:40px;color:var(--txt);font-size:14px;font-family:var(--font);outline:none;flex:1;padding:0 12px;transition:border-color .15s,box-shadow .15s}.name-form__input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.name-form__btn{border-radius:var(--r-sm);color:#fff;cursor:pointer;height:40px;font-size:14px;font-weight:600;font-family:var(--font);white-space:nowrap;border:none;padding:0 16px;transition:background .15s}.name-form__btn--green{background:var(--green)}.name-form__btn--green:hover{background:var(--green-hover)}.name-form__btn--red{background:var(--red)}.name-form__btn--red:hover{background:var(--red-hover)}.linked-codes{margin-top:14px}.linked-codes__title{color:var(--txt-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:600}.linked-codes__list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.linked-codes__item{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);font-family:var(--mono);color:var(--txt);justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;display:flex}.linked-codes__badge{font-family:var(--font);color:var(--blue);background:var(--blue-bg);border:1px solid var(--blue-border);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.linked-codes__del{background:var(--red-bg);border:1px solid var(--red-border);border-radius:var(--r-sm);width:26px;height:26px;color:var(--red);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;transition:background .15s,color .15s;display:flex}.linked-codes__del:hover{background:var(--red);color:#fff;border-color:var(--red)}.history-filter{border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);width:100%;max-width:400px;height:44px;color:var(--txt);font-size:14px;font-family:var(--font);outline:none;margin-bottom:16px;padding:0 14px;transition:border-color .15s,box-shadow .15s;display:block}.history-filter::placeholder{color:var(--txt-3)}.history-filter:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.history-filters{margin-bottom:16px}.history-filters .history-filter{margin-bottom:10px}.history-date-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.history-date-label{color:var(--txt-2);align-items:center;gap:6px;font-size:14px;display:flex}.history-date-input{border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);height:40px;color:var(--txt);font-size:14px;font-family:var(--font);outline:none;padding:0 12px;transition:border-color .15s,box-shadow .15s}.history-date-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.history-table__user{white-space:nowrap;color:var(--txt-2);font-size:13px}.history-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-xs);overflow-x:auto}.history-table{border-collapse:collapse;width:100%;font-size:13px}.history-table th{text-align:left;background:var(--bg);border-bottom:1px solid var(--border);color:var(--txt-2);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.history-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 14px}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:var(--bg)}.history-table__date{color:var(--txt-2);white-space:nowrap;font-size:12px}.history-table__name{color:var(--txt);font-weight:500}.history-table__barcode{font-family:var(--mono);color:var(--txt-2);font-size:12px}.history-table__action{border:1px solid;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.history-table__action--in{color:var(--green-txt);background:var(--green-bg);border-color:var(--green-border)}.history-table__action--out{color:var(--red);background:var(--red-bg);border-color:var(--red-border)}.history-table__action--edit{color:var(--txt-2);background:var(--bg-2);border-color:var(--border)}.history-table__empty{text-align:center;color:var(--txt-3);padding:40px 20px;font-size:14px}.products-wrap{max-width:900px;margin:0 auto;padding:20px 16px}.products-header h2{align-items:center;gap:8px;font-size:20px;font-weight:700;display:flex}.products-header h2:before{content:"";background:var(--blue);border-radius:2px;flex-shrink:0;width:4px;height:20px;display:block}.products-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-xs);overflow-x:auto}.products-table{border-collapse:collapse;width:100%;font-size:14px}.products-table th{text-align:left;background:var(--bg);border-bottom:1px solid var(--border);color:var(--txt-2);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:600}.products-table td{border-bottom:1px solid var(--border);color:var(--txt);vertical-align:middle;padding:12px 14px}.products-table tr:last-child td{border-bottom:none}.products-table tr:hover td{background:var(--bg);transition:background .1s}.products-table--compact th,.products-table--compact td{padding:9px 10px}.products-table--compact .num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.products-table--compact .products-table__name{white-space:normal;min-width:140px}.sale-row{cursor:pointer;transition:background .12s}.sale-row:hover td{background:var(--bg)}.sale-row--open td{background:var(--blue-bg)}.sale-row .num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.sale-caret{width:14px;color:var(--txt-3);margin-right:6px;transition:transform .15s;display:inline-block;transform:rotate(0)}.sale-caret--open{color:var(--blue);transform:rotate(90deg)}.sale-detail-row>td{background:var(--bg);border-bottom:1px solid var(--border);padding:0}.sale-detail{padding:4px 16px 10px 34px}.sale-detail__item{border-bottom:1px dashed var(--border);grid-template-columns:1fr auto minmax(96px,auto);align-items:baseline;gap:14px;padding:8px 0;display:grid}.sale-detail__item:last-child{border-bottom:none}.sale-detail__name{color:var(--txt);font-weight:500}.sale-detail__qty{color:var(--txt-2);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:13px}.sale-detail__sum{color:var(--txt);text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;font-weight:600}.products-table__barcode{font-family:var(--mono);color:var(--txt-2);font-size:12px}.products-table__name{font-weight:500}.products-table__no-name{color:var(--txt-3);font-size:13px;font-style:italic}.products-table__qty{font-variant-numeric:tabular-nums;font-weight:700}.products-table__price{color:var(--txt-2);font-variant-numeric:tabular-nums}.products-table__date{color:var(--txt-3);white-space:nowrap;font-size:12px}.products-table__edit-input{border-radius:var(--r-sm);border:1.5px solid var(--blue);background:var(--surface);width:100%;height:34px;color:var(--txt);font-size:14px;font-family:var(--font);box-shadow:0 0 0 3px var(--blue-bg);outline:none;padding:0 10px}.products-table__price-input{border-radius:var(--r-sm);border:1.5px solid var(--blue);background:var(--surface);width:90px;height:34px;color:var(--txt);font-size:14px;font-family:var(--font);box-shadow:0 0 0 3px var(--blue-bg);outline:none;padding:0 10px}.products-table__actions{justify-content:flex-end;gap:6px;display:flex}.btn-icon{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);height:32px;color:var(--txt-2);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;padding:0 12px;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn-icon:hover{background:var(--bg);color:var(--txt);border-color:var(--border-2)}.btn-icon--save{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue)}.btn-icon--save:hover{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-icon--del{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.btn-icon--del:hover{background:var(--red);color:#fff;border-color:var(--red)}.products-table__empty{text-align:center;color:var(--txt-3);padding:48px 20px;font-size:14px}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100svh;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:360px;box-shadow:var(--shadow-md);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:36px 32px;display:flex}.login-logo{background:var(--blue-bg);border:1px solid var(--blue-border);border-radius:var(--r-lg);justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:8px;font-size:24px;display:flex}.login-title{color:var(--txt);font-size:20px;font-weight:700}.login-subtitle{color:var(--txt-2);margin-bottom:8px;font-size:14px}.login-divider{background:var(--border);width:100%;height:1px;margin:8px 0}.login-btn{border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);width:100%;height:44px;color:var(--txt);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;box-shadow:var(--shadow-xs);justify-content:center;align-items:center;gap:8px;transition:background .15s,border-color .15s,box-shadow .15s;display:flex}.login-btn:hover{background:var(--bg);border-color:var(--border-2);box-shadow:var(--shadow-sm)}.login-btn--seller{background:var(--green-bg);border-color:var(--green-border);color:var(--green-txt)}.login-btn--seller:hover{background:var(--green);color:#fff;border-color:var(--green)}.login-btn--manager{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue)}.login-btn--manager:hover{background:var(--blue);color:#fff;border-color:var(--blue)}.login-dev-section{flex-direction:column;gap:8px;width:100%;display:flex}.login-dev-label{color:var(--txt-3);text-transform:uppercase;letter-spacing:.06em;text-align:left;font-size:11px;font-weight:600}.report-summary{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.report-summary__card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;flex:180px;padding:12px 16px}.report-summary__label{color:var(--txt-2);margin-bottom:6px;font-size:11px;line-height:1.4}.report-summary__value{color:var(--txt-1);font-size:18px;font-weight:700}.report-summary__value--green{color:var(--accent-green)}.dash-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--txt-2);margin:20px 0 8px;font-size:12px;font-weight:700}.dash-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-bottom:4px;display:grid}.dash-card{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:15px 17px}.dash-card__label{color:var(--txt-2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:11px;font-weight:600;line-height:1.3}.dash-card__value{color:var(--txt-1);font-size:22px;font-weight:800;line-height:1.2}.dash-chart{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;align-items:flex-end;gap:4px;height:80px;margin-bottom:4px;padding:10px 12px 28px;display:flex;overflow:hidden}.dash-chart__col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex;position:relative}.dash-chart__bar{background:var(--accent-green);opacity:.8;border-radius:3px 3px 0 0;width:100%;min-height:0;transition:height .3s}.dash-chart__label{color:var(--txt-3);white-space:nowrap;font-size:10px;position:absolute;bottom:-20px}.dash-top{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:4px;overflow:hidden}.dash-top__row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.dash-top__row:last-child{border-bottom:none}.dash-top__num{color:var(--txt-3);flex-shrink:0;width:16px;font-size:12px;font-weight:700}.dash-top__name{color:var(--txt-1);flex:1}.dash-top__units{color:var(--txt-2);flex-shrink:0;font-size:12px}.dash-top__revenue{color:var(--accent-green);text-align:right;flex-shrink:0;min-width:60px;font-weight:600}.dash-low{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:4px;overflow:hidden}.dash-low__row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:9px 14px;font-size:13px;display:flex}.dash-low__row:last-child{border-bottom:none}.dash-low__name{color:var(--txt-1);flex:1}.dash-low__qty{flex-shrink:0;font-weight:700}.report-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:16px;padding-bottom:0;display:flex}.report-tab{color:var(--txt-2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:14px}.report-tab--active{color:var(--accent-green);border-bottom-color:var(--accent-green);font-weight:600}.report-tab:hover:not(.report-tab--active){color:var(--txt-1)}.report-period{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.report-period__presets{flex-wrap:wrap;gap:4px;display:flex}.report-period__btn{background:var(--surface-2);border:1px solid var(--border);color:var(--txt-1);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:13px}.report-period__btn--active{background:var(--accent-green);border-color:var(--accent-green);color:#fff}.report-period__btn:hover:not(.report-period__btn--active){background:var(--surface-1)}.report-period__custom{align-items:center;gap:6px;display:flex}.report-period__date{background:var(--surface-2);border:1px solid var(--border);color:var(--txt-1);border-radius:6px;padding:5px 8px;font-size:13px}.report-period__apply{background:var(--surface-2);border:1px solid var(--border);color:var(--txt-1);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:13px}.report-period__apply:hover{background:var(--surface-1)}.batch-bar{align-items:center;gap:6px;margin-bottom:12px;font-size:13px;display:flex}.batch-bar__label{color:var(--txt-2)}.batch-bar__name{border:1px solid var(--border);color:var(--txt-1);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:13px}.batch-bar__name:hover{border-color:var(--accent-green)}.batch-bar__clear{color:var(--txt-3);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:14px}.batch-bar__view{border:1px solid var(--border);color:var(--accent-green);cursor:pointer;background:0 0;border-radius:8px;margin-top:12px;padding:8px 14px;font-size:13px;display:block}.batch-bar__view:hover{background:var(--surface-2)}.batch-picker{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:14px;padding:12px}.batch-picker__create{gap:8px;margin-bottom:10px;display:flex}.batch-picker__input{background:var(--surface-1);border:1px solid var(--border);color:var(--txt-1);border-radius:6px;flex:1;padding:6px 10px;font-size:13px}.batch-picker__btn{background:var(--accent-green);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:13px}.batch-picker__list{flex-direction:column;gap:4px;max-height:160px;display:flex;overflow-y:auto}.batch-picker__item{text-align:left;color:var(--txt-1);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 8px;font-size:13px}.batch-picker__item:hover{background:var(--surface-1)}.batch-list{flex-direction:column;gap:10px;display:flex}.batch-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);width:100%;box-shadow:var(--shadow-xs);cursor:pointer;text-align:left;font-family:var(--font);justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;transition:border-color .15s,box-shadow .15s,background .15s;display:flex}.batch-card:hover{border-color:var(--green-border);box-shadow:var(--shadow-sm);background:var(--green-bg)}.batch-card__name{color:var(--txt);font-size:16px;font-weight:600;line-height:1.3}.batch-card__date{color:var(--txt-2);white-space:nowrap;flex-shrink:0;font-size:13px}.batch-back{border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;font-weight:500;font-family:var(--font);color:var(--txt-2);cursor:pointer;background:0 0;align-items:center;gap:4px;margin-bottom:16px;padding:6px 14px;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.batch-back:hover{background:var(--bg);color:var(--txt);border-color:var(--border-2)}.batch-meta{color:var(--txt-2);flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:20px;font-size:14px;line-height:1.5;display:flex}.batch-meta strong{color:var(--txt)}.batch-meta__dot{color:var(--txt-3)}.stepper{border:1.5px solid var(--border);border-radius:var(--r);display:flex;overflow:hidden}.stepper__btn{background:var(--bg);cursor:pointer;width:40px;height:44px;color:var(--txt);border:none;font-size:18px;transition:background .15s}.stepper__btn:hover{background:var(--border)}.stepper__btn:active{transform:scale(.95)}.stepper__input{border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);text-align:center;background:var(--surface);color:var(--txt);-moz-appearance:textfield;outline:none;flex:1;min-width:0;font-size:20px;font-weight:700}.stepper__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stepper__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.stepper--price .stepper__btn{width:34px;font-size:16px}.stepper--readonly{background:var(--surface-2);border-radius:var(--r-sm);border:1px solid var(--border);padding:8px 12px}.stepper__value{color:var(--txt-2);font-size:14px;font-weight:500}.stepper--price .stepper__input::placeholder{color:var(--txt-3);font-size:12px}.stepper--error{box-shadow:0 0 0 2px var(--red-bg);border-color:var(--red-border)!important}@media (width<=560px){.page,.products-wrap{padding:14px 12px}.page__title{font-size:20px}.top-bar{gap:8px;padding:0 10px}.top-bar__user{text-overflow:ellipsis;white-space:nowrap;max-width:38vw;font-size:12px;overflow:hidden}.top-bar__right{gap:6px}.top-bar__layout{display:none}.top-bar__store-select{max-width:110px}.top-bar__logout{padding:5px 10px}.products-table-wrap,.history-table-wrap{border:1px solid var(--border);border-radius:var(--r);-webkit-overflow-scrolling:touch}.products-table,.history-table{font-size:12.5px}.products-table th,.history-table th{padding:8px;font-size:11px}.products-table td,.history-table td{padding:8px}.products-table__barcode,.history-table__barcode,.products-table__qty,.products-table__price,.products-table__date,.history-table__date,.history-table__action{white-space:nowrap}.login-card{padding:28px 20px}.scan-form{gap:8px}.scan-form__btn{padding:0 14px}.report-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.report-tab{white-space:nowrap;padding:9px 14px;font-size:14px}.report-summary{grid-template-columns:1fr 1fr;gap:8px;display:grid}.report-summary__card{padding:10px 12px}.report-summary__value{font-size:16px}.report-period{gap:10px}.report-period__presets{width:100%}.report-period__btn{padding:7px 12px;font-size:13px}.report-period__custom{flex-wrap:wrap;width:100%}.report-period__date{flex:40%;min-width:0;height:38px;font-size:14px}.report-period__apply{flex:100%;height:38px;font-size:14px}.dash-grid{grid-template-columns:1fr 1fr}.admin-section{padding:14px 12px}.admin-row{flex-direction:column;align-items:stretch}.admin-row .input,.admin-row select,.admin-row .btn{flex:none;min-width:0;width:100%!important;max-width:100%!important}.catalog-input{width:100%}.income-toolbar{flex-direction:column;gap:12px}.income-field{width:100%;min-width:0}.qty-fields{grid-template-columns:1fr;gap:14px}.confirm-block--stacked,.qty-field,.stepper{min-width:0}}@media (width<=380px){.report-summary,.dash-grid{grid-template-columns:1fr}.confirm-block{flex-wrap:wrap}.confirm-block__btn{flex:100%}}@media (width>=768px){html:not(.force-mobile) .mobile-nav,html:not(.force-mobile) .mobile-drawer,html:not(.force-mobile) .mobile-drawer-overlay{display:none}html:not(.force-mobile) #root{margin-left:56px;padding-bottom:0}html:not(.force-mobile) .top-bar{margin-left:56px;padding-left:20px;position:sticky;top:0}html:not(.force-mobile) .bottom-nav{border-top:none;border-right:1px solid var(--border);z-index:200;flex-direction:column;justify-content:flex-start;align-items:center;width:56px;height:100vh;padding:12px 4px;transition:width .2s,padding .2s,box-shadow .2s;display:flex;position:fixed;inset:0 auto 0 0;overflow:hidden auto;box-shadow:2px 0 16px #0000000f}html:not(.force-mobile) .bottom-nav:hover{align-items:stretch;width:200px;padding:12px 10px;box-shadow:4px 0 24px #0000001f}html.dark:not(.force-mobile) .bottom-nav{box-shadow:2px 0 16px #00000040}html.dark:not(.force-mobile) .bottom-nav:hover{box-shadow:4px 0 24px #0006}html:not(.force-mobile) .nav-tab{min-width:unset;border-radius:var(--r);white-space:nowrap;flex-direction:row;justify-content:center;align-items:center;gap:10px;padding:10px 0;overflow:hidden}html:not(.force-mobile) .bottom-nav:hover .nav-tab{justify-content:flex-start;padding:10px 12px}html:not(.force-mobile) .nav-tab__icon{border-radius:var(--r-sm);background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;display:flex}html:not(.force-mobile) .nav-tab--active{background:var(--blue-bg)}html:not(.force-mobile) .nav-tab--active .nav-tab__icon{color:var(--blue);background:0 0}html:not(.force-mobile) .nav-tab__label{text-transform:none;letter-spacing:0;opacity:0;width:0;font-size:14px;transition:opacity .15s,width .2s;display:block;overflow:hidden}html:not(.force-mobile) .bottom-nav:hover .nav-tab__label{opacity:1;width:auto}html:not(.force-mobile) .page{max-width:900px}html:not(.force-mobile) .products-wrap{max-width:1100px}html:not(.force-mobile) .confirm-block{bottom:16px}}.top-bar__store-select{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg);height:28px;color:var(--txt);font-size:13px;font-family:var(--font);cursor:pointer;max-width:160px;padding:0 8px}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:16px;padding:16px}.admin-section__title{color:var(--txt);margin-bottom:12px;font-size:14px;font-weight:600}.admin-row{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.admin-row .input{flex:1;min-width:120px}.admin-list{flex-direction:column;gap:6px;margin-top:8px;display:flex}.admin-list__row{background:var(--bg);border-radius:var(--r-sm);align-items:center;gap:8px;padding:6px 10px;font-size:13px;display:flex}.admin-list__name{color:var(--txt);flex:1;font-weight:500}.admin-list__sub{color:var(--txt-2);font-size:12px}.admin-list__id{color:var(--txt-3);font-size:12px;font-family:var(--mono)}.admin-empty{color:var(--txt-3);padding:8px 0;font-size:13px}.admin-users{flex-direction:column;gap:10px;display:flex}.admin-user{background:var(--bg);border-radius:var(--r-sm);padding:10px 12px}.admin-user__head{align-items:center;gap:10px;margin-bottom:8px;display:flex}.admin-user__pic{object-fit:cover;border-radius:50%;width:32px;height:32px}.admin-user__info{flex:1;min-width:0}.admin-user__name{color:var(--txt);font-size:13px;font-weight:500}.admin-user__email{color:var(--txt-3);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.admin-user__stores{flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.admin-user__stores-label{color:var(--txt-2)}.admin-user__store-tag{background:var(--blue-bg);border:1px solid var(--blue-border);color:var(--blue);border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:12px;display:inline-flex}.admin-user__store-rm{cursor:pointer;color:var(--txt-3);background:0 0;border:none;padding:0;font-size:11px;line-height:1}.admin-user__store-rm:hover{color:var(--red)}.btn--sm{padding:4px 8px;font-size:12px}.input--sm{height:28px;padding:0 8px;font-size:12px}:root{--brand:#6366f1;--brand-2:#8b5cf6;--brand-3:#d946ef;--grad:linear-gradient(135deg, #6366f1 0%, #8b5cf6 55%, #a855f7 100%);--grad-soft:linear-gradient(135deg, #6366f11f, #a855f71f);--blue:#6366f1;--blue-hover:#4f46e5;--blue-bg:#eef2ff;--blue-border:#c7d2fe;--bg:#eef1f8;--surface:#fff;--border:#e6e8f0;--border-2:#d3d8e6;--r-sm:8px;--r:14px;--r-lg:20px;--shadow-xs:0 1px 2px #0f172a0f;--shadow-sm:0 2px 8px -2px #0f172a1f;--shadow-md:0 10px 24px -8px #4f46e52e, 0 4px 8px -4px #0f172a14;--shadow-lg:0 24px 48px -16px #4f46e547}html.dark{--brand:#818cf8;--brand-2:#a78bfa;--grad:linear-gradient(135deg, #6366f1 0%, #8b5cf6 60%, #c026d3 100%);--blue:#818cf8;--blue-hover:#a5b4fc;--blue-bg:#6366f129;--blue-border:#818cf859;--bg:#0b1020;--surface:#151c30;--border:#273350;--border-2:#36456b;--shadow-md:0 12px 28px -10px #0000008c;--shadow-lg:0 28px 56px -18px #000000a6}html{background:var(--bg)}body{background-color:#0000;background-image:radial-gradient(900px 500px at 100% -5%,#a855f71a,#0000 60%),radial-gradient(800px 460px at -10% 0,#6366f11f,#0000 55%);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box;background-clip:border-box,border-box;min-height:100svh}.top-bar{z-index:50;background:color-mix(in srgb, var(--surface) 78%, transparent);-webkit-backdrop-filter:saturate(160%)blur(14px);border-bottom:1px solid var(--border);box-shadow:var(--shadow-xs);position:sticky;top:0}.top-bar:before{content:"◆ Учёт товаров";letter-spacing:-.02em;background:var(--grad);color:#0000;-webkit-background-clip:text;background-clip:text;margin-right:auto;padding-right:14px;font-size:15px;font-weight:800}.top-bar__user{color:var(--txt-2);font-weight:600}.bottom-nav,.mobile-nav{background:color-mix(in srgb, var(--surface) 88%, transparent);-webkit-backdrop-filter:saturate(160%)blur(16px);border-top:1px solid var(--border);box-shadow:0 -10px 30px -16px #4f46e559}.nav-tab{border-radius:var(--r);transition:color .15s,background .15s,transform .12s}.nav-tab:active{transform:translateY(1px)scale(.97)}.nav-tab--active{color:var(--brand)}.nav-tab--active .nav-tab__icon{background:var(--grad);color:#fff;box-shadow:0 6px 14px -4px #6366f199}.page__title{letter-spacing:-.025em}.page__title:before{background:var(--grad);border-radius:4px;width:5px}.product-card,.dash-card,.report-summary__card{border-radius:var(--r-lg);box-shadow:var(--shadow-md);transition:transform .18s,box-shadow .18s}.product-card{position:relative;overflow:hidden}.product-card:after{content:"";background:var(--grad);height:4px;position:absolute;inset:0 0 auto}.dash-card:hover,.report-summary__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.scan-form__btn,.confirm-block__btn,.btn-icon--save{transition:transform .12s,box-shadow .18s,filter .18s;box-shadow:0 8px 18px -8px #6366f1b3;background:var(--grad)!important;color:#fff!important;border:none!important}.scan-form__btn:hover,.confirm-block__btn:hover:not(:disabled),.btn-icon--save:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 12px 24px -8px #6366f1cc}.scan-form__btn--green,.confirm-block__btn--green{box-shadow:0 8px 18px -8px #10b981b3;background:linear-gradient(135deg,#10b981,#16a34a)!important}.scan-form__btn--red,.confirm-block__btn--red{box-shadow:0 8px 18px -8px #f43f5e99;background:linear-gradient(135deg,#f43f5e,#dc2626)!important}.products-table-wrap{border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:auto hidden}.products-table th{text-transform:uppercase;letter-spacing:.06em;background:var(--grad-soft);color:var(--txt-2);font-size:11px}.products-table tr:hover td{background:var(--blue-bg)}.dash-card__value{letter-spacing:-.03em}.report-summary__card{border-top:3px solid #0000;border-image:var(--grad) 1}.scan-form__input:focus,.products-table__edit-input:focus,.products-table__price-input:focus,.report-period__date:focus,.top-bar__store-select:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #6366f12e}.report-tab--active,.report-period__btn--active{box-shadow:0 6px 14px -6px #6366f1b3;background:var(--grad)!important;color:#fff!important;border-color:#0000!important}.login-page{background:radial-gradient(1100px 700px at 110% -10%,#d946ef47,#0000 55%),radial-gradient(1000px 680px at -10% 110%,#6366f152,#0000 55%),linear-gradient(160deg,#0b1020 0%,#1b1840 55%,#2a1d4a 100%);min-height:100svh}.login-card{background:color-mix(in srgb, var(--surface) 86%, transparent);-webkit-backdrop-filter:saturate(160%)blur(18px);border:1px solid #ffffff24;border-radius:24px;box-shadow:0 40px 80px -24px #0009}.login-logo{filter:drop-shadow(0 8px 18px #6366f180);font-size:44px}.login-title{background:var(--grad);color:#0000;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-weight:800}.login-btn{transition:transform .12s,box-shadow .18s,filter .18s}.login-btn:hover{filter:brightness(1.03);transform:translateY(-1px)}.login-btn--seller,.login-btn--manager{box-shadow:0 8px 18px -8px #6366f1b3;background:var(--grad)!important;color:#fff!important;border:none!important}.scan-form__input,.products-table__edit-input,.products-table__price-input,.report-period__date,.top-bar__store-select,.name-form__input{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);height:46px;padding:0 14px;font-size:15px;transition:border-color .15s,box-shadow .15s,background .15s}.products-table__edit-input,.products-table__price-input{height:38px}.scan-form__input{box-shadow:var(--shadow-xs)}.scan-form__btn,.confirm-block__btn{letter-spacing:.01em;border-radius:var(--r);height:48px;font-weight:700}.btn-icon{border:1.5px solid var(--border);border-radius:9px;height:34px;font-weight:600;transition:transform .12s,box-shadow .15s,background .15s,color .15s,border-color .15s}.btn-icon:hover{transform:translateY(-1px)}.dash-section-title{letter-spacing:-.01em;color:var(--txt);margin-top:26px;font-weight:700}@media (width>=768px){html:not(.force-mobile) #root{margin-left:236px}html:not(.force-mobile) .top-bar{margin-left:236px;padding-left:22px}html:not(.force-mobile) .top-bar:before{content:none}html:not(.force-mobile) .bottom-nav{-webkit-backdrop-filter:none;backdrop-filter:none;background:linear-gradient(#4338ca 0%,#6d28d9 60%,#7e22ce 100%);border-right:none;align-items:stretch;gap:3px;width:236px;padding:0 12px 16px;box-shadow:4px 0 30px -10px #4f46e573}html:not(.force-mobile) .bottom-nav:hover{width:236px;padding:0 12px 16px}html:not(.force-mobile) .bottom-nav:before{content:"◆  Учёт товаров";letter-spacing:-.02em;color:#fff;border-bottom:1px solid #ffffff24;align-items:center;height:60px;margin-bottom:10px;padding:0 12px;font-size:16px;font-weight:800;display:flex}html:not(.force-mobile) .nav-tab{color:#ffffffbd;border-radius:11px;flex-direction:row;justify-content:flex-start;align-items:center;gap:12px;padding:11px 13px;font-weight:600}html:not(.force-mobile) .bottom-nav:hover .nav-tab{justify-content:flex-start;padding:11px 13px}html:not(.force-mobile) .nav-tab:hover{color:#fff;background:#ffffff1a}html:not(.force-mobile) .nav-tab__icon{width:24px;height:24px;color:inherit;font-size:16px;box-shadow:none!important;background:0 0!important}html:not(.force-mobile) .nav-tab__label{opacity:1;width:auto;font-size:14.5px;font-weight:600}html:not(.force-mobile) .nav-tab--active{color:#fff;background:#ffffff29;box-shadow:inset 3px 0 #fff}html:not(.force-mobile) .nav-tab--active .nav-tab__icon{color:#fff;background:0 0!important}}.nav-tab__icon{font-variant-emoji:text;font-family:var(--font)}@media (width>=768px){html:not(.force-mobile) #root{margin-left:66px}html:not(.force-mobile) .top-bar{margin-left:66px;padding-left:22px}html:not(.force-mobile) .top-bar:before{content:none}html:not(.force-mobile) .bottom-nav{background:var(--surface);border-right:1px solid var(--border);width:66px;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:none;backdrop-filter:none;align-items:stretch;gap:4px;padding:0 10px 14px;transition:width .22s,box-shadow .22s;overflow:hidden}html:not(.force-mobile) .bottom-nav:hover{width:240px;box-shadow:var(--shadow-lg);padding:0 10px 14px}html:not(.force-mobile) .bottom-nav:before{content:"◆";letter-spacing:-.02em;white-space:nowrap;border-bottom:1px solid var(--border);background:var(--grad);color:#0000;-webkit-background-clip:text;background-clip:text;justify-content:center;align-items:center;height:58px;margin-bottom:8px;font-size:20px;font-weight:800;display:flex;overflow:hidden}html:not(.force-mobile) .bottom-nav:hover:before{content:"◆  Учёт товаров";justify-content:flex-start;padding-left:12px;font-size:17px}html:not(.force-mobile) .nav-tab{color:var(--txt-2);border-radius:11px;flex-direction:row;justify-content:center;align-items:center;gap:0;padding:11px 0;font-weight:600;transition:background .15s,color .15s,padding .2s}html:not(.force-mobile) .bottom-nav:hover .nav-tab{justify-content:flex-start;gap:13px;padding:11px 13px}html:not(.force-mobile) .nav-tab:hover{background:var(--blue-bg);color:var(--brand)}html:not(.force-mobile) .nav-tab__icon{width:26px;height:26px;color:inherit;flex-shrink:0;font-size:18px;box-shadow:none!important;background:0 0!important}html:not(.force-mobile) .nav-tab__label{opacity:0;white-space:nowrap;width:0;font-size:14.5px;font-weight:600;transition:opacity .15s,width .2s;overflow:hidden}html:not(.force-mobile) .bottom-nav:hover .nav-tab__label{opacity:1;width:auto}html:not(.force-mobile) .nav-tab--active,html:not(.force-mobile) .nav-tab--active:hover{background:var(--grad);color:#fff;box-shadow:0 6px 14px -6px #6366f199}html:not(.force-mobile) .nav-tab--active .nav-tab__icon{color:#fff}}.catalog-grid{grid-template-columns:1fr;align-items:start;gap:18px;display:grid}@media (width>=760px){.catalog-grid{grid-template-columns:1fr 1fr}}.catalog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:20px}.catalog-card__title{align-items:center;gap:10px;margin-bottom:16px;font-size:16px;display:flex}.catalog-card__count{color:var(--brand);background:var(--blue-bg);border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700}.catalog-form{flex-direction:column;gap:10px;margin-bottom:18px;display:flex}.catalog-input{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);width:100%;height:44px;color:var(--txt);padding:0 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.catalog-input::placeholder{color:var(--txt-3)}.catalog-input:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #6366f12e}.catalog-add-btn{border-radius:var(--r);background:var(--grad);color:#fff;cursor:pointer;border:none;height:44px;font-size:14px;font-weight:700;transition:transform .12s,filter .18s,opacity .15s;box-shadow:0 8px 18px -8px #6366f1b3}.catalog-add-btn:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px)}.catalog-add-btn:disabled{opacity:.45;cursor:default;box-shadow:none}.catalog-list{max-height:460px;margin:0;padding:0;list-style:none;overflow-y:auto}.catalog-list__row{border-radius:10px;align-items:center;gap:10px;padding:11px 12px;transition:background .12s;display:flex}.catalog-list__row:hover{background:var(--surface-2)}.catalog-list__row+.catalog-list__row{border-top:1px solid var(--border)}.catalog-list__name{font-size:14.5px;font-weight:600}.catalog-list__meta{color:var(--txt-2);margin-left:auto;font-size:13px}.catalog-list__del{border:1px solid var(--border);background:var(--surface);width:28px;height:28px;color:var(--txt-3);cursor:pointer;border-radius:8px;flex-shrink:0;margin-left:auto;font-size:13px;line-height:1;transition:background .12s,color .12s,border-color .12s}.catalog-list__meta+.catalog-list__del{margin-left:10px}.catalog-list__del:hover{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.catalog-list__empty{color:var(--txt-3);text-align:center;padding:18px 12px;font-size:14px}.income-context-bar{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;padding:8px 12px;display:flex}.income-context-bar__item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;flex-direction:column;gap:1px;padding:2px 6px;display:flex}.income-context-bar__item:hover{background:var(--border)}.income-context-bar__label{color:var(--txt-3);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.income-context-bar__value{color:var(--green);font-size:13px;font-weight:600}.income-context-bar__sep{color:var(--txt-3);font-size:18px;line-height:1}.income-context-bar__view-btn{border:1.5px solid var(--border);color:var(--txt-2);cursor:pointer;white-space:nowrap;background:0 0;border-radius:999px;margin-left:auto;padding:4px 12px;font-size:12px;font-weight:600;transition:border-color .15s,color .15s}.income-context-bar__view-btn:hover{border-color:var(--green);color:var(--green)}.batch-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);margin-bottom:14px;overflow:hidden}.batch-panel__toolbar{border-bottom:1px solid var(--border);background:var(--bg);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 14px;display:flex}.batch-panel__all-toggle{color:var(--txt-2);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:13px;display:flex}.batch-panel__all-toggle input{accent-color:var(--green);cursor:pointer;width:15px;height:15px}.batch-panel__sup-select{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--txt);cursor:pointer;padding:4px 8px;font-size:13px;font-weight:600}.batch-panel__count{color:var(--txt-3);margin-left:auto;font-size:12px}.batch-panel__empty{color:var(--txt-3);padding:16px 14px;font-size:13px}.batch-panel__table-wrap{overflow-x:auto}.batch-panel__table{border-collapse:collapse;width:100%;font-size:13px}.batch-panel__table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-3);border-bottom:1px solid var(--border);white-space:nowrap;padding:8px 12px;font-size:11px}.batch-panel__table td{border-bottom:1px solid var(--border);padding:8px 12px}.batch-panel__table tr:last-child td{border-bottom:none}.batch-panel__name{max-width:180px;font-weight:500}.batch-panel__sup{color:var(--txt-2)}.income-drill-create{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.income-drill-create .catalog-input{flex:1;min-width:180px}.income-drill-list{flex-direction:column;gap:6px;display:flex}.income-drill-item{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;text-align:left;align-items:center;gap:10px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.income-drill-item:hover{border-color:var(--green);background:var(--green-bg,color-mix(in srgb, var(--green) 8%, transparent))}.income-drill-item__name{color:var(--txt);flex:1;font-size:15px;font-weight:500}.income-drill-item__meta{color:var(--txt-3);font-size:12px}.income-drill-item__arrow{color:var(--txt-3);font-size:20px}.income-toolbar{flex-wrap:wrap;gap:12px;margin-bottom:14px;display:flex}.income-field{flex-direction:column;flex:1;gap:6px;min-width:170px;display:flex}.income-field__label{letter-spacing:.06em;text-transform:uppercase;color:var(--txt-3);font-size:11px;font-weight:700}.income-field__control{align-items:center;gap:8px;display:flex}.income-pill,.income-select{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);width:100%;height:44px;color:var(--txt);padding:0 14px;font-size:14.5px;font-weight:600;transition:border-color .15s,box-shadow .15s}.income-pill{cursor:pointer;flex:1;justify-content:space-between;align-items:center;display:flex}.income-pill__caret{color:var(--txt-3);margin-left:8px}.income-pill:hover,.income-select:hover{border-color:var(--border-2)}.income-select:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #6366f12e}.income-pill__clear{border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);width:44px;height:44px;color:var(--txt-3);cursor:pointer;flex-shrink:0;font-size:14px;transition:background .12s,color .12s,border-color .12s}.income-pill__clear:hover{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.batch-picker{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:14px}.batch-picker__input{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);height:42px;padding:0 12px;font-size:14px}.batch-picker__btn{border-radius:var(--r);background:var(--grad);height:42px;padding:0 16px;font-weight:700;box-shadow:0 8px 18px -8px #6366f1b3}.batch-picker__item{border-radius:9px;padding:9px 12px;font-size:14px;font-weight:500}.batch-picker__item--active{background:var(--blue-bg);color:var(--brand);font-weight:700}.confirm-block--stacked{flex-direction:column;align-items:stretch;gap:14px}.qty-fields{grid-template-columns:1fr 1fr;gap:12px;display:grid}.qty-field{flex-direction:column;gap:7px;display:flex}.qty-field__label{letter-spacing:.06em;text-transform:uppercase;color:var(--txt-3);font-size:11px;font-weight:700}.confirm-block--stacked .confirm-block__btn{flex:none;width:100%}.stepper{border-radius:var(--r);background:var(--surface);height:48px}.stepper__btn{background:var(--surface-2);width:46px;color:var(--txt);cursor:pointer;border:none;font-size:20px;font-weight:600;transition:background .12s,color .12s}.stepper__btn:hover{background:var(--blue-bg);color:var(--brand)}.stepper--price .stepper__input{font-size:17px;font-weight:700}.product-card__details{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);gap:0;padding:4px 14px}html.dark .product-card__details{background:#ffffff0a}.product-card__row{padding:11px 0;font-size:14px}.product-card__row+.product-card__row{border-top:1px solid var(--border)}.product-card__label{font-size:13px}.product-card__value{font-size:14px}.product-card__edit-btn{border-radius:999px;padding:4px 12px}.product-card__edit-btn:hover{background:var(--blue-bg);color:var(--brand);border-color:var(--blue-border)}.segmented{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r);gap:4px;height:48px;padding:4px;display:flex}.segmented__btn{color:var(--txt-2);cursor:pointer;font-size:13.5px;font-weight:600;font-family:var(--font);background:0 0;border:none;border-radius:9px;flex:1;transition:background .15s,color .15s,box-shadow .15s}.segmented__btn:hover{color:var(--txt)}.segmented__btn--active{background:var(--grad);color:#fff;box-shadow:0 4px 10px -4px #6366f199}.return-types{flex-direction:column;gap:8px;margin:14px 0;display:flex}.return-type{text-align:left;cursor:pointer;border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--txt);font-size:14.5px;font-weight:600;font-family:var(--font);align-items:center;gap:11px;padding:13px 14px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.return-type:hover{border-color:var(--border-2)}.return-type__radio{border:2px solid var(--border-2);border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:border-color .15s,box-shadow .15s}.return-type--active{border-color:var(--brand);background:var(--blue-bg);box-shadow:0 0 0 3px #6366f11f}.return-type--active .return-type__radio{border-color:var(--brand);box-shadow:inset 0 0 0 4px var(--brand)}.page h3{letter-spacing:-.01em;font-size:16px;font-weight:700}.report-tabs{gap:6px}.report-tab{border:1.5px solid var(--border);background:var(--surface);color:var(--txt-2);border-radius:999px;padding:7px 16px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.report-tab:hover{border-color:var(--border-2);color:var(--txt)}.report-period__btn{border:1.5px solid var(--border);background:var(--surface);color:var(--txt-2);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s}.report-period__btn:hover{border-color:var(--border-2);color:var(--txt)}.report-period__apply{background:var(--grad);color:#fff;border:none;border-radius:999px;padding:7px 16px;font-weight:700;box-shadow:0 6px 14px -6px #6366f199}.alert{border-radius:var(--r);border:1px solid #0000;font-weight:500}.alert--error{background:var(--red-bg);border-color:var(--red-border);color:var(--red)}.alert--warning{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber-txt)}.report-summary__card{border-radius:var(--r-lg)}.report-summary__value{letter-spacing:-.02em}.combo{width:100%;position:relative}.combo__trigger{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);width:100%;height:44px;color:var(--txt);cursor:pointer;font-size:14.5px;font-weight:600;font-family:var(--font);justify-content:space-between;align-items:center;gap:8px;padding:0 14px;transition:border-color .15s,box-shadow .15s;display:flex}.combo__trigger:hover{border-color:var(--border-2)}.combo__placeholder{color:var(--txt-3);font-weight:500}.combo__caret{color:var(--txt-3);flex-shrink:0}.combo__pop{z-index:60;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);flex-direction:column;gap:6px;padding:8px;display:flex;position:absolute;top:calc(100% + 6px);left:0;right:0}.combo__search{border:1.5px solid var(--border);background:var(--surface-2);height:38px;color:var(--txt);border-radius:9px;padding:0 12px;font-size:14px}.combo__search:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #6366f12e}.combo__list{flex-direction:column;gap:2px;max-height:260px;display:flex;overflow-y:auto}.combo__opt{text-align:left;cursor:pointer;color:var(--txt);font-size:14px;font-weight:500;font-family:var(--font);background:0 0;border:none;border-radius:8px;padding:9px 11px;transition:background .12s,color .12s}.combo__opt:hover{background:var(--surface-2)}.combo__opt--active{background:var(--blue-bg);color:var(--brand);font-weight:700}.combo__empty{text-align:center;color:var(--txt-3);padding:12px;font-size:13px}.report-summary{gap:12px}.report-summary__card{background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--brand);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border-image:;flex:170px;padding:14px 16px}.report-summary__label{letter-spacing:.04em;text-transform:uppercase;color:var(--txt-3);margin-bottom:8px;font-size:11px;font-weight:600}.report-summary__value{letter-spacing:-.02em;font-size:22px;font-weight:800}.report-period{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;align-items:stretch;gap:12px;padding:14px}.report-period__presets{gap:6px}.report-period__custom{flex-wrap:wrap;gap:8px}.report-period__date{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);height:40px;padding:0 12px;font-size:14px}.report-period__btn{align-items:center;height:36px;display:inline-flex}.report-period__apply{height:40px}.report-tabs{margin-bottom:16px}.page,.products-wrap{padding:24px 18px 40px}@media (width>=768px){html:not(.force-mobile) .page,html:not(.force-mobile) .products-wrap{padding:30px 28px 48px}}.page__title{margin:0 0 22px}.products-header{margin-bottom:20px}.dash-section-title{margin:26px 0 12px}.page h3{margin:26px 0 14px}.page h3:first-child{margin-top:0}.report-period,.report-summary,.report-tabs{margin-bottom:18px}.income-toolbar,.alert,.scan-form{margin-bottom:16px}.product-card,.catalog-card{padding:22px}.products-table-wrap{margin-top:4px}.page .catalog-card__title{margin:0 0 18px}.sale-total{border-radius:var(--r);background:var(--surface-2);border:1px solid var(--border);justify-content:space-between;align-items:baseline;padding:12px 16px;display:flex}.sale-total span{color:var(--txt-2);font-size:13px;font-weight:600}.sale-total strong{letter-spacing:-.02em;font-size:20px;font-weight:800}.qty-field__req{color:var(--red);font-weight:700}.dash-section-title{letter-spacing:.07em;text-transform:uppercase;color:var(--txt-3);align-items:center;gap:8px;margin:28px 0 12px;font-size:12px;font-weight:700;display:flex}.dash-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:16px 18px;position:relative;overflow:hidden}.dash-card:before{content:"";background:var(--grad);width:4px;position:absolute;top:0;bottom:0;left:0}.dash-card__label{letter-spacing:.04em;text-transform:uppercase;color:var(--txt-3);margin-bottom:8px;font-size:11px;font-weight:600}.dash-card__value{letter-spacing:-.03em;font-size:24px;font-weight:800}.dash-card__sub{color:var(--txt-3);margin-top:5px;font-size:12px}.dash-chart{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);height:132px;box-shadow:var(--shadow-sm);gap:6px;padding:16px 16px 30px}.dash-chart__bar{background:var(--grad);opacity:1;border-radius:6px 6px 0 0;transition:filter .15s,height .3s;box-shadow:0 4px 10px -4px #6366f180}.dash-chart__bar:hover{filter:brightness(1.1)}.dash-chart__label{font-size:11px;font-weight:600;bottom:-22px}.dash-top{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.dash-top__row{gap:12px;padding:12px 16px;font-size:14px}.dash-top__row:hover{background:var(--surface-2)}.dash-top__num{background:var(--grad);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:800;display:flex}.dash-top__name{font-weight:600}.dash-top__units{background:var(--surface-2);color:var(--txt-2);border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}.dash-top__revenue{letter-spacing:-.02em;min-width:80px;font-weight:800}.dash-low{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.dash-low__row{padding:11px 16px;font-size:14px}.dash-low__row:hover{background:var(--surface-2)}.dash-low__name{font-weight:600}.dash-low__qty{background:var(--surface-2);border-radius:999px;padding:4px 11px;font-size:12.5px;font-weight:700}.login-page{z-index:100;position:fixed;inset:0;overflow:auto}.income-empty-hint{border:1.5px dashed var(--border-2);border-radius:var(--r);background:var(--surface-2);height:44px;color:var(--brand);align-items:center;padding:0 14px;font-size:14px;font-weight:600;text-decoration:none;transition:border-color .15s,background .15s;display:flex}.income-empty-hint:hover{border-color:var(--brand);background:var(--blue-bg)}.input{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);width:100%;height:44px;color:var(--txt);font-size:15px;font-family:var(--font);padding:0 14px;transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--txt-3)}.input:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #6366f12e}.input--sm{width:auto;height:38px;padding:0 10px;font-size:13.5px}.btn{border-radius:var(--r);border:1.5px solid var(--border);background:var(--surface);height:44px;color:var(--txt);cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font);justify-content:center;align-items:center;gap:6px;padding:0 18px;transition:transform .12s,filter .18s,background .15s,border-color .15s,opacity .15s;display:inline-flex}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.45;cursor:default}.btn--primary{color:#fff;background:var(--grad);border:none;box-shadow:0 8px 18px -8px #6366f1b3}.btn--danger{color:#fff;background:linear-gradient(135deg,#f43f5e,#dc2626);border:none;box-shadow:0 8px 18px -8px #f43f5e99}.btn--sm{height:34px;padding:0 12px;font-size:13px}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);margin-bottom:18px;padding:22px}.admin-section__title{letter-spacing:-.01em;margin-bottom:16px;font-size:16px;font-weight:700}.admin-row{align-items:center;gap:10px}.admin-list{gap:4px}.admin-list__row{background:var(--surface-2);border-radius:10px;padding:11px 14px;font-size:14px;transition:background .12s}.admin-list__row:hover{background:var(--blue-bg)}.admin-list__name{font-weight:600}.admin-list__id{background:var(--surface);border-radius:999px;padding:2px 9px}.admin-user{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px}.admin-user__name{font-size:14.5px;font-weight:700}.admin-user__email{font-size:12px}.admin-user__store-tag{background:var(--blue-bg);border:1px solid var(--blue-border);color:var(--brand);border-radius:999px;padding:4px 10px;font-weight:600}.admin-user__store-rm{color:var(--brand);opacity:.6}.admin-user__store-rm:hover{color:var(--red);opacity:1}.sale-readonly{border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface-2);height:46px;color:var(--txt);letter-spacing:-.02em;align-items:center;padding:0 14px;font-size:17px;font-weight:800;display:flex}.qty-field__hint{color:var(--txt-3);margin-top:6px;font-size:12px}.alert--success{background:var(--green-bg);border-color:var(--green-border);color:var(--green-txt)}.checkout-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);flex-direction:column;gap:12px;margin-top:16px;padding:16px;display:flex;position:sticky;bottom:16px}.stepper--inline{max-width:130px;height:36px}.stepper--inline .stepper__btn{width:34px;font-size:16px}.stepper--inline .stepper__input{font-size:14px}.checkout-bar .confirm-block__btn{flex:none;height:50px}.checkout-bar .product-card__cancel{margin-top:0}.confirm-block__btn--soft{background:var(--surface-2)!important;color:var(--txt)!important;border:1.5px solid var(--border-2)!important;box-shadow:none!important}.confirm-block__btn--soft:hover:not(:disabled){filter:none;border-color:var(--brand)!important}.toast{z-index:300;pointer-events:none;color:#fff;background:linear-gradient(135deg,#10b981,#16a34a);border-radius:999px;padding:10px 18px;font-size:14px;font-weight:700;animation:.15s toast-in;position:fixed;bottom:92px;left:50%;transform:translate(-50%);box-shadow:0 12px 28px -8px #10b98199}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@media (width>=768px){html:not(.force-mobile) .toast{bottom:32px;left:calc(50% + 33px)}}.toast--warn{background:linear-gradient(135deg,#f43f5e,#dc2626);bottom:140px;box-shadow:0 12px 28px -8px #f43f5e99}@media (width>=768px){html:not(.force-mobile) .toast--warn{bottom:80px}}.price-cell{flex-direction:column;gap:4px;display:flex}.price-cell__cost{color:var(--amber-txt);background:var(--amber-bg);border:1px solid var(--amber-border);white-space:nowrap;border-radius:6px;align-self:flex-start;padding:2px 6px;font-size:12px;font-weight:700}.checkout-bar .sale-total{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1px;padding:10px 16px}.checkout-bar .sale-total span{color:var(--txt-2);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.checkout-bar .sale-total strong{letter-spacing:-.03em;background:var(--grad);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:30px;line-height:1.1}@media (width<=480px){.checkout-bar .sale-total strong{font-size:26px}}.checkout-items{max-height:46vh;overflow:auto}.checkout-items thead th{z-index:1;background:var(--surface);position:sticky;top:0}.checkout-page{flex-direction:column;height:calc(100svh - 132px);padding-top:16px;padding-bottom:12px;display:flex}@media (width>=768px){html:not(.force-mobile) .checkout-page{height:calc(100svh - 52px)}}.checkout-page .page__title,.checkout-page .scan-form,.checkout-page .alert{flex:none}.checkout-scroll{flex:auto;min-height:0;margin:2px 0 10px;overflow-y:auto}.checkout-scroll thead th{z-index:1;background:var(--surface);position:sticky;top:0}.checkout-page .checkout-bar{flex:none;margin-top:0;position:static;bottom:auto}.checkout-page .page__title{margin-bottom:14px;font-size:19px}.checkout-page .scan-form{margin-bottom:12px}.checkout-page .scan-form__input,.checkout-page .scan-form__btn{height:42px;font-size:14px}.checkout-page .cart-item{gap:10px;padding:7px 12px}.checkout-page .cart-item__name{font-size:13px}.checkout-page .cart-item__sum{font-size:14px}.checkout-page .cart-item__price-input,.checkout-page .qstep{height:32px}.checkout-page .qstep__btn{width:32px;font-size:16px}.checkout-page .qstep__input{font-size:14px}.checkout-page .checkout-bar{gap:10px;padding:12px}.checkout-page .checkout-bar .confirm-block__btn{height:46px;font-size:13.5px}.checkout-page .checkout-bar .sale-total{padding:8px 14px}.checkout-page .checkout-bar .sale-total strong{font-size:26px}.checkout-page .quickpick-tile{min-height:58px;padding:8px 10px}.checkout-row{align-items:stretch;gap:12px;display:flex}.checkout-row .sale-total{text-align:center;background:var(--surface-2);border-radius:var(--r);flex:auto;justify-content:center;align-items:center;padding:10px 16px}.checkout-row .sale-total strong{font-size:30px}@media (width<=480px){.checkout-row .sale-total strong{font-size:26px}}.segmented--compact{flex-direction:column;flex:none;gap:4px;width:130px;height:auto}.segmented--compact .segmented__btn{padding:9px 10px}.pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin:16px 0 4px;display:flex}.pagination__btn,.pagination__num{border:1.5px solid var(--border);background:var(--surface);min-width:34px;height:34px;color:var(--txt);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);border-radius:9px;padding:0 10px;transition:background .12s,color .12s,border-color .12s,transform .1s}.pagination__btn:hover:not(:disabled),.pagination__num:hover{border-color:var(--brand);color:var(--brand)}.pagination__btn:disabled{opacity:.4;cursor:default}.pagination__num--active{background:var(--grad);color:#fff;border-color:#0000;box-shadow:0 6px 14px -6px #6366f1b3}.pagination__dots{color:var(--txt-3);padding:0 2px}.pagination__total{color:var(--txt-3);margin-left:8px;font-size:13px}.pair-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);grid-template-columns:auto 1fr;align-items:start;gap:20px 24px;max-width:760px;padding:20px;display:grid}.pair-qr-box{flex-direction:column;align-items:center;gap:10px;display:flex}.pair-qr{border-radius:var(--r);width:220px;height:220px;box-shadow:var(--shadow-sm);background:#fff;padding:8px}.pair-status{color:var(--txt-2);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.pair-dot{background:var(--txt-3);border-radius:50%;width:9px;height:9px;transition:background .2s}.pair-status--on{color:var(--accent-green,#16a34a)}.pair-status--on .pair-dot{background:var(--accent-green,#16a34a);box-shadow:0 0 0 3px #16a34a33}.pair-info{min-width:0}.pair-steps{color:var(--txt);margin:0 0 14px;padding-left:18px;font-size:14px;line-height:1.6}.pair-steps li{margin-bottom:4px}.pair-code{color:var(--txt-2);margin-bottom:4px;font-size:14px}.pair-code b{font-family:var(--mono);color:var(--txt);letter-spacing:.04em}.pair-link{color:var(--brand);word-break:break-all;font-size:12px}.pair-scans{border-top:1px solid var(--border);grid-column:1/-1;padding-top:14px}.pair-scans__title{text-transform:uppercase;letter-spacing:.06em;color:var(--txt-3);margin-bottom:8px;font-size:12px}.pair-scans__empty{color:var(--txt-3);font-size:13px}.pair-scans__row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;padding:7px 0;font-size:14px;display:flex}.pair-scans__row:last-child{border-bottom:none}.pair-scans__code{font-family:var(--mono);color:var(--txt)}.pair-scans__time{color:var(--txt-3);font-size:12px}@media (width<=560px){.pair-card{grid-template-columns:1fr}.pair-qr{width:200px;height:200px}}.scan{z-index:1000;color:#fff;font-family:var(--font);background:#07090e;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.scan__top{z-index:3;padding:max(14px, env(safe-area-inset-top)) 18px 12px;justify-content:space-between;align-items:center;display:flex;position:relative}.scan__brand{letter-spacing:-.01em;font-size:16px;font-weight:800}.scan__pill{color:#cbd2dd;background:#ffffff14;border:1px solid #ffffff1f;border-radius:999px;align-items:center;gap:7px;padding:6px 12px;font-size:12.5px;font-weight:700;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.scan__pill-dot{background:#9aa3b2;border-radius:50%;width:8px;height:8px}.scan__pill--ok{color:#6ee7b7;background:#10b98129;border-color:#10b98166}.scan__pill--ok .scan__pill-dot{background:#10b981;box-shadow:0 0 0 3px #10b98140}.scan__pill--lost{color:#fca5a5;background:#f43f5e29;border-color:#f43f5e66}.scan__pill--lost .scan__pill-dot{background:#f43f5e}.scan__stage{background:#000;flex:auto;min-height:0;position:relative;overflow:hidden}.scan__video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.scan__frame{aspect-ratio:5/3;border-radius:18px;width:min(78%,360px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 100vmax #00000073}.scan__corner{border:3px solid #818cf8;width:30px;height:30px;position:absolute}.scan__corner--tl{border-bottom:none;border-right:none;border-top-left-radius:16px;top:-2px;left:-2px}.scan__corner--tr{border-bottom:none;border-left:none;border-top-right-radius:16px;top:-2px;right:-2px}.scan__corner--bl{border-top:none;border-right:none;border-bottom-left-radius:16px;bottom:-2px;left:-2px}.scan__corner--br{border-top:none;border-left:none;border-bottom-right-radius:16px;bottom:-2px;right:-2px}.scan__laser{background:linear-gradient(90deg,#0000,#818cf8,#c4b5fd,#818cf8,#0000);border-radius:2px;height:2.5px;animation:2s ease-in-out infinite scan-laser;position:absolute;top:0;left:8px;right:8px;box-shadow:0 0 12px 2px #818cf8cc}@keyframes scan-laser{0%,to{top:6%}50%{top:94%}}.scan__tip{text-align:center;color:#ffffffd9;text-shadow:0 1px 8px #0009;font-size:14px;font-weight:600;position:absolute;bottom:18%;left:0;right:0}.scan__flash{background:#10b98166;animation:.22s scan-flash;position:absolute;inset:0}@keyframes scan-flash{0%{opacity:1}to{opacity:0}}.scan__intro{background:radial-gradient(120% 80% at 50% 0,#141a2b 0%,#07090e 70%);justify-content:center;align-items:center;padding:26px;display:flex;position:absolute;inset:0}.scan__intro-card{text-align:center;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:22px;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:360px;padding:30px 24px;display:flex;box-shadow:0 20px 50px -20px #000000b3}.scan__intro-icon{letter-spacing:2px;color:#818cf8;background:#818cf81f;border-radius:16px;padding:12px 16px;font-size:30px}.scan__intro-title{letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800}.scan__intro-sub{color:#aab2c0;margin:0;font-size:14.5px;line-height:1.5}.scan__start{cursor:pointer;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:14px;width:100%;margin-top:4px;padding:16px;font-size:16px;font-weight:800;transition:transform .12s,filter .2s;box-shadow:0 14px 30px -10px #6366f1cc}.scan__start:active{filter:brightness(1.05);transform:scale(.98)}.scan__intro-code{font-family:var(--mono);color:#6b7280;font-size:12px}.scan__bottom{z-index:3;padding:14px 18px max(16px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000059;border-top:1px solid #ffffff14;align-items:center;gap:12px;display:flex;position:relative}.scan__result{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.scan__result-label{text-transform:uppercase;letter-spacing:.07em;color:#6ee7b7;font-size:11px;font-weight:700}.scan__result-code{font-family:var(--mono);letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;font-size:19px;font-weight:700;overflow:hidden}.scan__result--has{animation:.2s scan-pop}@keyframes scan-pop{0%{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}.scan__result-empty{color:#9aa3b2;font-size:14px}.scan__actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.scan__count{color:#c4b5fd;background:#818cf82e;border:1px solid #818cf859;border-radius:999px;justify-content:center;align-items:center;min-width:40px;height:40px;padding:0 12px;font-size:16px;font-weight:800;display:inline-flex}.scan__stop{color:#fff;cursor:pointer;background:0 0;border:1.5px solid #ffffff40;border-radius:12px;padding:10px 16px;font-size:14px;font-weight:700}.scan__stop:active{background:#ffffff14}.cart{flex-direction:column;gap:8px;width:100%;display:flex}.cart-col-name{flex:auto;min-width:0}.cart-col-qty{flex:0 0 116px;width:116px}.cart-col-price{flex:0 0 120px;width:120px}.cart-col-sum{text-align:right;flex:0 0 110px;width:110px}.cart-col-del{flex:0 0 28px;width:28px}.cart-head{text-transform:uppercase;letter-spacing:.06em;color:var(--txt-3);align-items:center;gap:14px;margin-bottom:2px;padding:2px 14px;font-size:11px;font-weight:700;display:flex}.cart-head .cart-col-qty{text-align:center}.cart-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);align-items:center;gap:14px;padding:9px 14px;display:flex}.cart-item__name{text-overflow:ellipsis;white-space:nowrap;color:var(--txt);font-size:14px;font-weight:600;overflow:hidden}.qstep{border:1.5px solid var(--border);background:var(--surface);border-radius:9px;align-items:center;height:36px;display:inline-flex;overflow:hidden}.qstep__btn{background:var(--surface-2);width:36px;height:100%;color:var(--txt);cursor:pointer;border:none;font-size:18px;font-weight:600;transition:background .12s,color .12s}.qstep__btn:hover{background:var(--blue-bg);color:var(--brand)}.qstep__btn:active{transform:scale(.94)}.qstep__input{border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);text-align:center;background:var(--surface);min-width:0;height:100%;color:var(--txt);-moz-appearance:textfield;outline:none;flex:1;font-size:16px;font-weight:700}.qstep__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.qstep__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cart-col-price{flex-direction:column;justify-content:center;gap:2px;display:flex}.cart-item__unit{color:var(--txt-2);font-variant-numeric:tabular-nums;font-size:14px}.cart-item__cost{color:var(--amber-txt,#b45309);white-space:nowrap;font-size:10.5px}.cart-item__warn{color:var(--amber-txt);background:var(--amber-bg);border:1px solid var(--amber-border);white-space:nowrap;border-radius:6px;padding:2px 8px;font-size:11px}.cart-item__price-input--warn{border-color:var(--amber-border)!important;background:var(--amber-bg)!important}.cart-item__price-input{border:1.5px solid var(--border);background:var(--surface);width:100%;height:36px;color:var(--txt);-moz-appearance:textfield;border-radius:9px;outline:none;padding:0 10px;font-size:14px;transition:border-color .15s,box-shadow .15s}.cart-item__price-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #6366f12e}.cart-item__price-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cart-item__price-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cart-item__sum{color:var(--txt);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:15px;font-weight:800}.cart-item__del{border:1px solid var(--border);background:var(--surface);height:28px;color:var(--txt-3);cursor:pointer;border-radius:8px;font-size:12px;transition:background .12s,color .12s,border-color .12s}.cart-item__del:hover{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}@media (width<=560px){.cart-head{display:none}.cart-item{flex-wrap:wrap;gap:10px}.cart-col-name{flex:100%}.cart-col-qty{flex:none;width:auto}.cart-col-price{flex:0 0 110px;width:110px}.cart-col-sum{text-align:right;flex:auto;width:auto}}.scan-form__btn--active{background:var(--brand);color:#fff;border-color:var(--brand)}.quickpick-panel{border:1.5px solid var(--border);background:var(--surface);border-radius:14px;flex-direction:column;gap:8px;margin-bottom:12px;padding:10px;display:flex}.quickpick-tabs{background:var(--surface-2);border:1.5px solid var(--border);border-radius:12px;gap:4px;height:44px;padding:4px;display:flex}.quickpick-tabs .segmented__btn{font-size:14px}.quickpick-search{border:1.5px solid var(--border);background:var(--surface-2);width:100%;color:var(--txt);border-radius:10px;outline:none;padding:9px 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.quickpick-search:focus{border-color:var(--brand);box-shadow:0 0 0 3px #6366f126}.quickpick-weight-modal{background:var(--surface-2);border:1.5px solid var(--brand);border-radius:12px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.quickpick-weight-modal__name{font-size:16px;font-weight:700}.quickpick-weight-modal__price{color:var(--txt-2);font-size:12px}.quickpick-weight-modal__row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.quickpick-weight-modal__input{border:1.5px solid var(--border);background:var(--surface);min-width:120px;max-width:200px;height:42px;color:var(--txt);-moz-appearance:textfield;border-radius:10px;outline:none;flex:1;padding:0 14px;font-size:18px;font-weight:700;transition:border-color .15s}.quickpick-weight-modal__input:focus{border-color:var(--brand)}.quickpick-weight-modal__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.quickpick-weight-modal__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quickpick-weight-modal__preview{color:var(--green);font-variant-numeric:tabular-nums;font-size:20px;font-weight:800}.quickpick-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;max-height:260px;padding-right:2px;display:grid;overflow-y:auto}.quickpick-empty{color:var(--txt-2);text-align:center;grid-column:1/-1;padding:14px 0;font-size:13px}.quickpick-tile{border:1.5px solid var(--border);background:var(--surface-2);color:var(--txt);cursor:pointer;text-align:left;border-radius:12px;flex-direction:column;align-items:flex-start;gap:4px;min-height:68px;padding:10px 12px;transition:background .12s,border-color .15s,transform .1s;display:flex;position:relative}.quickpick-tile:hover:not(.quickpick-tile--empty){background:var(--blue-bg);border-color:var(--brand)}.quickpick-tile:active:not(.quickpick-tile--empty){transform:scale(.97)}.quickpick-tile--in-cart{border-color:var(--green);background:var(--green-bg,#22c55e14)}.quickpick-tile--empty{opacity:.45;cursor:default}.quickpick-tile__name{font-size:13px;font-weight:600;line-height:1.3}.quickpick-tile__price{color:var(--txt-2);font-size:12px}.quickpick-tile__badge{background:var(--brand);color:#fff;border-radius:8px;padding:1px 6px;font-size:11px;font-weight:700;position:absolute;top:6px;right:8px}.quickpick-tile__badge--out{background:var(--red)}.quickpick-tile__reweigh{border:1px dashed var(--border);color:var(--txt-2);cursor:pointer;background:0 0;border-radius:8px;padding:4px 10px;font-size:13px;transition:border-color .12s,color .12s}.quickpick-tile__reweigh:hover{border-color:var(--brand);color:var(--brand)}.field-group{flex-direction:column;gap:4px;display:flex}.field-label{color:var(--txt-2);font-size:12px;font-weight:500}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#02061799;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);color:var(--txt);border:1.5px solid var(--border);border-radius:16px;width:min(480px,95vw);max-height:90vh;padding:22px;overflow-y:auto;box-shadow:0 30px 70px -25px #000000b3}.modal-card__title{color:var(--txt);font-size:19px;font-weight:700}.modal-card__sub{color:var(--txt-2);margin:2px 0 18px;font-size:14px}.customer-list{border:1.5px solid var(--border);background:var(--surface-1);border-radius:10px;max-height:168px;margin-bottom:10px;overflow-y:auto}.customer-list__item{cursor:pointer;color:var(--txt);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;transition:background .12s;display:flex}.customer-list__item:last-child{border-bottom:none}.customer-list__item:hover{background:var(--bg)}.customer-list__item--active{background:var(--blue-bg);font-weight:600}.customer-list__phone{color:var(--txt-2);font-size:13px}.customer-list__empty{color:var(--txt-2);padding:10px 12px;font-size:13px}.sup-section{margin-top:28px}.sup-section__header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;display:flex}.sup-section__summary{flex-wrap:wrap;gap:8px;display:flex}.sup-summary-badge{border-radius:20px;padding:4px 12px;font-size:13px;font-weight:700}.sup-summary-badge--debt{color:#c53030;background:#dc505026;border:1px solid #fca5a5}.sup-summary-badge--over{color:#166534;background:#22c55e1f;border:1px solid #86efac}.sup-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.sup-row{border:1.5px solid var(--border);background:var(--surface);border-radius:12px;overflow:hidden}.sup-row__head{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:12px 16px;transition:background .12s;display:flex}.sup-row__head:hover{background:var(--surface-2)}.sup-row__info{flex:none;min-width:150px}.sup-row__name{font-size:15px;font-weight:700;display:block}.sup-row__contact{color:var(--txt-2);font-size:12px;display:block}.sup-row__nums{flex-wrap:wrap;flex:auto;align-items:center;gap:4px 14px;display:flex}.sup-row__label{color:var(--txt-2);font-size:12px}.sup-row__val{font-variant-numeric:tabular-nums;font-size:13px}.sup-row__balance{font-variant-numeric:tabular-nums;border-radius:12px;padding:3px 10px;font-size:14px;font-weight:800}.sup-row__balance--debt{color:#c53030;background:#dc505026}.sup-row__balance--over{color:#166534;background:#22c55e1f}.sup-row__balance--zero{background:var(--surface-2);color:var(--txt-2);font-weight:500}.sup-row__toggle{color:var(--txt-2);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:12px}.sup-row__body{border-top:1px solid var(--border);background:var(--surface-2);padding:12px 16px 16px}.sup-pay-form{flex-wrap:wrap;align-items:flex-end;gap:8px;margin-bottom:10px;display:flex}.sup-pay-form__input{border:1.5px solid var(--border);background:var(--surface);width:140px;height:38px;color:var(--txt);-moz-appearance:textfield;border-radius:9px;outline:none;padding:0 12px;font-size:15px;font-weight:700;transition:border-color .15s}.sup-pay-form__input:focus{border-color:var(--brand)}.sup-pay-form__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.sup-pay-form__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.sup-pay-form__note{border:1.5px solid var(--border);background:var(--surface);min-width:160px;height:38px;color:var(--txt);border-radius:9px;outline:none;flex:1;padding:0 12px;font-size:14px;transition:border-color .15s}.sup-pay-form__note:focus{border-color:var(--brand)}.sup-pay-form__date{border:1.5px solid var(--border);background:var(--surface);width:140px;height:38px;color:var(--txt);border-radius:9px;outline:none;padding:0 10px;font-size:14px;transition:border-color .15s}.sup-pay-form__date:focus{border-color:var(--brand)}.sup-pay-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.sup-pay-row{background:var(--surface);border-radius:8px;align-items:center;gap:10px;padding:6px 10px;font-size:13px;display:flex}.sup-pay-row__date{color:var(--txt-2);min-width:90px}.sup-pay-row__amount{color:#166534;font-variant-numeric:tabular-nums;font-weight:700}.sup-pay-row__note{color:var(--txt-2);flex:1;font-style:italic}.sup-pay-empty{color:var(--txt-2);padding:4px 0;font-size:13px}.pattern-lock-overlay{z-index:10000;background:var(--bg);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pattern-lock{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:24px;display:flex}.pattern-lock__title{color:var(--txt);font-size:18px;font-weight:600}.pattern-lock__svg{touch-action:none;cursor:pointer;width:min(360px,80vw);height:min(360px,80vw)}.pattern-lock--error{animation:.4s ease-in-out pattern-shake}@keyframes pattern-shake{0%,to{transform:translate(0)}15%{transform:translate(-12px)}30%{transform:translate(10px)}45%{transform:translate(-8px)}60%{transform:translate(6px)}75%{transform:translate(-3px)}}
