:root{--c-brand: #2c5cff;--c-brand-2: #6e8bff;--c-brand-deep: #1535b8;--c-brand-glow: rgba(44, 92, 255, .45);--c-bg: #f3f5fb;--c-bg-deep: #eef1f8;--c-surface: #ffffff;--c-surface-alt: #f8fafd;--c-surface-hover: #f1f4fb;--c-surface-soft: #fafbff;--c-border: #e5e8f1;--c-border-strong: #d4d9e6;--c-text: #0e1726;--c-text-muted: #5a6478;--c-text-subtle: #8b94a8;--c-text-inverse: #ffffff;--c-primary: #2c5cff;--c-primary-hover: #1f49d9;--c-primary-soft: #e7eeff;--c-primary-softer: #f3f6ff;--c-danger: #d92d20;--c-danger-hover: #b42318;--c-danger-soft: #fef3f2;--c-success: #067647;--c-success-hover: #045a37;--c-success-soft: #ecfdf3;--c-warning: #b54708;--c-warning-soft: #fffaeb;--c-info: #0b5cff;--c-info-soft: #eaf1ff;--c-shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--c-shadow-sm: 0 2px 4px rgba(15, 23, 42, .05);--c-shadow: 0 1px 2px rgba(15, 23, 42, .06), 0 4px 12px rgba(15, 23, 42, .04);--c-shadow-lg: 0 6px 12px -4px rgba(15, 23, 42, .08), 0 18px 30px -8px rgba(15, 23, 42, .14);--c-shadow-xl: 0 24px 48px -16px rgba(15, 23, 42, .22);--c-shadow-glow: 0 8px 24px -8px var(--c-brand-glow);--radius: 14px;--radius-sm: 10px;--radius-xs: 8px;--radius-pill: 999px;--sidebar-w: 248px;--sidebar-w-collapsed: 72px;--header-h: 60px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--ease-soft: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);color:var(--c-text);background:radial-gradient(1200px 800px at -10% -20%,rgba(44,92,255,.05),transparent 50%),radial-gradient(900px 600px at 110% 110%,rgba(110,139,255,.06),transparent 55%),var(--c-bg);background-attachment:fixed;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02","cv03","cv04","cv11";overflow-x:hidden}h1,h2,h3,h4{margin:0;font-weight:600;color:var(--c-text);letter-spacing:-.015em}h1{font-size:24px;line-height:1.25;letter-spacing:-.02em}h2{font-size:18px}h3{font-size:15.5px}p{margin:0}a{color:var(--c-primary);text-decoration:none}a:hover{color:var(--c-primary-hover)}.mono{font-family:var(--font-mono);font-size:.92em;letter-spacing:-.01em}code{font-family:var(--font-mono);background:var(--c-surface-alt);padding:2px 6px;border-radius:5px;font-size:.88em;color:var(--c-text);border:1px solid var(--c-border)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:#0f172a29;border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background-color:#0f172a4d}*::-webkit-scrollbar-track{background:transparent}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;background:radial-gradient(900px 600px at 50% 30%,rgba(44,92,255,.18),transparent 65%),radial-gradient(800px 600px at 50% 100%,rgba(110,139,255,.12),transparent 60%),#0b1220;color:#fff;animation:splashFadeIn .4s var(--ease-soft)}.splash--leaving{animation:splashFadeOut .5s var(--ease-soft) forwards}.splash__core{display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center}.splash__logo-wrap{position:relative;width:128px;height:128px;display:grid;place-items:center;border-radius:28px;background:linear-gradient(135deg,#ffffff2e,#ffffff0a);box-shadow:0 0 0 1px #ffffff14 inset,0 30px 80px -20px #2c5cff99,0 0 60px #2c5cff66;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:splashPop .9s var(--ease-spring),splashGlow 2.6s ease-in-out infinite alternate;overflow:hidden}.splash__logo-wrap:before{content:"";position:absolute;top:-40%;right:-40%;bottom:-40%;left:-40%;background:conic-gradient(from 0deg,#2c5cff00,#2c5cff66,#2c5cff00 50%);animation:splashSpin 4s linear infinite;opacity:.7}.splash__logo{position:relative;width:96px;height:96px;border-radius:22px;object-fit:cover;z-index:1;box-shadow:0 8px 24px #0006}.splash__title{font-size:28px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(180deg,#fff,#c5d0ff);-webkit-background-clip:text;background-clip:text;color:transparent;animation:splashRise .7s .15s var(--ease-soft) backwards}.splash__sub{color:#9aa6c5;font-size:13px;letter-spacing:.04em;text-transform:uppercase;animation:splashRise .7s .3s var(--ease-soft) backwards}.splash__bar{width:220px;height:4px;border-radius:999px;background:#ffffff14;overflow:hidden;margin-top:8px}.splash__bar-fill{width:40%;height:100%;border-radius:999px;background:linear-gradient(90deg,transparent,var(--c-brand-2),transparent);animation:splashLoading 1.4s ease-in-out infinite}@keyframes splashPop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}@keyframes splashGlow{0%{box-shadow:0 0 0 1px #ffffff14 inset,0 30px 80px -20px #2c5cff80,0 0 40px #2c5cff4d}to{box-shadow:0 0 0 1px #ffffff1a inset,0 30px 90px -20px #2c5cffd9,0 0 80px #6e8bff8c}}@keyframes splashSpin{to{transform:rotate(360deg)}}@keyframes splashRise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes splashFadeIn{0%{opacity:0}to{opacity:1}}@keyframes splashFadeOut{to{opacity:0;visibility:hidden}}@keyframes splashLoading{0%{transform:translate(-150%)}to{transform:translate(350%)}}.splash--login{background:#ffffff59;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.splash--login .splash__logo-wrap{background:#ffffffe6;box-shadow:0 20px 60px #2c5cff40,0 4px 20px #00000014}.splash__title--dark{background:none;-webkit-background-clip:unset;background-clip:unset;color:#0e1726}.splash__sub--dark{color:#5a6478}.app-shell{min-height:100vh;position:relative}.app-content{margin-left:var(--sidebar-w-collapsed);display:flex;flex-direction:column;min-width:0;min-height:100vh}.app-main{flex:1;padding:28px 32px 32px;overflow-x:hidden;animation:pageEnter .36s var(--ease-soft)}@keyframes pageEnter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.topbar{display:none;align-items:center;gap:12px;padding:12px 16px;background:var(--c-surface);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb}.topbar__brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.01em}.topbar__brand-logo{width:32px;height:32px;border-radius:8px;object-fit:cover;box-shadow:var(--c-shadow)}.icon-btn{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--c-border-strong);background:var(--c-surface);color:var(--c-text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.icon-btn:hover{background:var(--c-surface-hover);color:var(--c-text);border-color:var(--c-border-strong)}.sidebar{background:linear-gradient(180deg,#0c1426,#0a1020);color:#d6deef;display:flex;flex-direction:column;padding:18px 12px;gap:14px;border-right:1px solid rgba(255,255,255,.05);position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w-collapsed);z-index:30;transition:width .3s var(--ease-soft),box-shadow .3s var(--ease-soft),transform .3s var(--ease-soft);overflow:hidden;will-change:width}@media (min-width: 961px){.sidebar:not(.sidebar--collapsed){width:var(--sidebar-w);box-shadow:0 18px 40px #080c1e52}}.sidebar__head{display:flex;align-items:center;gap:12px;padding:4px 8px 8px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.sidebar__logo{width:40px;height:40px;border-radius:11px;object-fit:cover;box-shadow:0 6px 16px #2c5cff59,0 0 0 1px #ffffff14;flex-shrink:0;background:#fff}.sidebar__title-wrap{display:flex;flex-direction:column;min-width:0;flex:1;opacity:1;transition:opacity .2s}.sidebar__title{font-weight:700;color:#fff;font-size:15px;letter-spacing:-.01em;white-space:nowrap}.sidebar__subtitle{color:#8a94a6;font-size:11px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.sidebar__close-mobile{display:none;width:30px;height:30px;border:0;background:#ffffff14;color:#c2cbe0;border-radius:8px;cursor:pointer;place-items:center;flex-shrink:0;transition:background .15s,color .15s}.sidebar__close-mobile:hover{background:#ffffff29;color:#fff}.sidebar__nav{display:flex;flex-direction:column;gap:2px;margin-top:4px;overflow-y:auto;overflow-x:hidden;flex:1;padding-right:2px}.sidebar__nav::-webkit-scrollbar-thumb{background:#ffffff1a}.sidebar__group-label{color:#6e7894;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:14px 12px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__link{display:flex;align-items:center;gap:12px;color:#b9c2d0;text-decoration:none;padding:10px 12px;border-radius:var(--radius-xs);font-weight:500;font-size:13.5px;transition:background .15s,color .15s,transform .15s;position:relative;white-space:nowrap;overflow:hidden}.sidebar__link:hover{background:#ffffff0d;color:#fff}.sidebar__link--active{background:linear-gradient(90deg,#2c5cff38,#2c5cff14);color:#fff;box-shadow:inset 3px 0 0 var(--c-brand-2)}.sidebar__link--active:hover{background:linear-gradient(90deg,#2c5cff47,#2c5cff1a)}.sidebar__link-icon{width:22px;height:22px;display:grid;place-items:center;flex-shrink:0;color:#98a2bd;transition:color .15s,transform .2s}.sidebar__link--active .sidebar__link-icon{color:var(--c-brand-2)}.sidebar__link:hover .sidebar__link-icon{color:#fff}.sidebar__link-text{opacity:1;transition:opacity .2s;flex:1;text-overflow:ellipsis;overflow:hidden}.sidebar__footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.06);padding-top:12px;display:flex;flex-direction:column;gap:10px;flex-shrink:0}.sidebar__user{display:flex;align-items:center;gap:10px;padding:4px;border-radius:var(--radius-xs);overflow:hidden}.sidebar__user--btn{width:100%;background:none;border:1px solid transparent;cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.sidebar__user--btn:hover{background:#ffffff0f;border-color:#ffffff14}.sidebar__user--active{background:#ffffff12!important;border-color:#ffffff1a!important}.sidebar__user-dropdown{background:#0e1b30;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xs);overflow:hidden;animation:fadeIn .12s ease-out}.sidebar__user-dropdown-item{width:100%;padding:10px 14px;display:flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;font-size:13px;color:#fca5a5;transition:background .12s,color .12s}.sidebar__user-dropdown-item:hover{background:#d92d202e;color:#ffd4d0}.sidebar__avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#3b6fff,#7e9cff);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0;box-shadow:0 2px 6px #2c5cff59}.sidebar__user-info{min-width:0;opacity:1;transition:opacity .2s;flex:1}.sidebar__user-name{color:#fff;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{color:#8a94a6;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase}@media (min-width: 961px){.sidebar--collapsed .sidebar__title-wrap{opacity:0;pointer-events:none;flex:none;width:0;overflow:hidden}.sidebar--collapsed .sidebar__head{justify-content:center}.sidebar--collapsed .sidebar__user-info{opacity:0;pointer-events:none}.sidebar--collapsed .sidebar__link-text{opacity:0;pointer-events:none;flex:none;width:0;overflow:hidden}.sidebar--collapsed .sidebar__link{justify-content:center;padding:10px 0}.sidebar--collapsed .sidebar__group-label{text-align:center;font-size:0;line-height:16px;padding:14px 0 6px;position:relative}.sidebar--collapsed .sidebar__group-label:after{content:"";display:block;margin:0 auto;width:16px;height:1px;background:#ffffff1a}.sidebar--collapsed .sidebar__user-dropdown{display:none}}.sidebar-rail-toggle{position:fixed;top:20px;left:var(--sidebar-w-collapsed);width:26px;height:52px;border-radius:0 10px 10px 0;border:1px solid rgba(255,255,255,.08);border-left:none;background:#0c1426;color:#fffc;display:grid;place-items:center;cursor:pointer;z-index:31;box-shadow:4px 0 14px #080c1e8c;transition:left .3s var(--ease-soft),color .18s,background .18s,width .18s,box-shadow .18s,transform .18s}.sidebar-rail-toggle:not(.sidebar-rail-toggle--collapsed){left:var(--sidebar-w)}.sidebar-rail-toggle:hover{background:#1e3a6e;color:#fff;width:34px;box-shadow:5px 0 22px #2c5cff73,0 0 0 1px #2c5cff33;border-color:#6496ff40}.sidebar-rail-toggle svg{transition:transform .3s var(--ease-soft);filter:drop-shadow(0 0 3px rgba(255,255,255,.15))}.sidebar-rail-toggle:hover svg{filter:drop-shadow(0 0 5px rgba(150,190,255,.5))}.sidebar-rail-toggle--collapsed svg{transform:rotate(180deg)}@media (max-width: 960px){.sidebar-rail-toggle{display:none}}.sidebar-desktop-backdrop{display:none}@media (min-width: 961px){.sidebar-desktop-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;left:var(--sidebar-w);z-index:29;cursor:default}}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:29;animation:fadeIn .18s ease-out}.page{display:flex;flex-direction:column;gap:24px;max-width:1360px;margin:0 auto;width:100%}.page__header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}.page__subtitle{color:var(--c-text-muted);margin:4px 0 0;font-size:13px}.page__actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.page__footer-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--c-border);background:var(--c-surface-alt)}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--c-shadow-sm);overflow:hidden;transition:box-shadow .2s var(--ease-soft),transform .2s var(--ease-soft)}.card--split>:first-child{padding:18px 20px;border-bottom:1px solid var(--c-border);display:flex;gap:12px;align-items:flex-end;background:var(--c-surface-alt)}.card__header{padding:18px 20px;border-bottom:1px solid var(--c-border);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.card__body{padding:20px}.card--scroll-x{overflow:hidden}.table-wrap{overflow-x:auto}.filters-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:16px 20px;border-bottom:1px solid var(--c-border);background:var(--c-surface-alt);align-items:end}.filters-bar__clear{height:38px;align-self:end;justify-self:start}.field{display:flex;flex-direction:column;gap:6px}.field>span{font-size:11.5px;font-weight:600;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.04em}.field__hint{font-size:11.5px;color:var(--c-text-subtle)}.field__hint--error{color:var(--c-danger)}.input{font:inherit;font-size:14px;padding:9px 12px;border:1px solid var(--c-border-strong);background:#fff;border-radius:var(--radius-sm);color:var(--c-text);width:100%;outline:none;transition:border-color .18s,box-shadow .18s,background .18s;height:38px}.input:focus{border-color:var(--c-primary);box-shadow:0 0 0 4px #2c5cff24}.input--sm{padding:6px 10px;font-size:13px;height:34px}.input--num{width:110px;text-align:right;margin-left:auto}.input--error,.input--error:focus{border-color:var(--c-danger);box-shadow:0 0 0 4px #d92d201f}select.input{background-image:linear-gradient(45deg,transparent 50%,var(--c-text-muted) 50%),linear-gradient(135deg,var(--c-text-muted) 50%,transparent 50%);background-position:calc(100% - 18px) 16px,calc(100% - 13px) 16px;background-size:5px 5px,5px 5px;background-repeat:no-repeat;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:32px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field--col-2{grid-column:span 2}.form-grid__footer{grid-column:span 2;display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.category-form{display:flex;gap:12px;align-items:flex-end}.category-form .field{flex:1}.checkbox{display:inline-flex;align-items:center;gap:8px;color:var(--c-text-muted);font-size:13px;-webkit-user-select:none;user-select:none;cursor:pointer}.checkbox input{accent-color:var(--c-primary)}.btn{font:inherit;font-weight:600;font-size:13.5px;line-height:1;border:1px solid transparent;background:var(--c-surface);color:var(--c-text);padding:10px 16px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,color .15s,border-color .15s,opacity .15s,box-shadow .18s,transform .1s;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.btn:hover:not(:disabled){background:var(--c-surface-hover)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:linear-gradient(180deg,#356bff,var(--c-primary));color:#fff;border-color:var(--c-primary);box-shadow:0 1px #ffffff2e inset,0 6px 14px -6px var(--c-brand-glow)}.btn--primary:hover:not(:disabled){background:linear-gradient(180deg,var(--c-primary),var(--c-primary-hover));border-color:var(--c-primary-hover);box-shadow:0 1px #ffffff2e inset,0 8px 18px -6px var(--c-brand-glow)}.btn--danger{background:#fff;color:var(--c-danger);border-color:var(--c-border-strong)}.btn--danger:hover:not(:disabled){background:var(--c-danger-soft);border-color:var(--c-danger);color:var(--c-danger-hover)}.btn--danger-solid{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}.btn--danger-solid:hover:not(:disabled){background:var(--c-danger-hover);border-color:var(--c-danger-hover)}.btn--ghost{background:transparent;color:var(--c-text-muted);border-color:var(--c-border-strong)}.btn--ghost:hover:not(:disabled){background:var(--c-surface-alt);color:var(--c-text)}.btn--success{background:var(--c-success);color:#fff;border-color:var(--c-success)}.btn--success:hover:not(:disabled){background:var(--c-success-hover);border-color:var(--c-success-hover)}.btn--sm{padding:7px 12px;font-size:12.5px}.btn--lg{padding:13px 22px;font-size:14.5px}.btn--block{width:100%}.table{width:100%;border-collapse:collapse;font-size:13.5px}.table th,.table td{text-align:center;padding:13px 18px;border-bottom:1px solid var(--c-border);vertical-align:middle}.table thead th{background:var(--c-surface-alt);font-weight:600;color:var(--c-text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding-top:11px;padding-bottom:11px;position:sticky;top:0;z-index:1}.th--sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s,background .15s}.th--sortable:hover{color:var(--c-text);background:var(--c-surface-hover)}.th--sortable:focus-visible{outline:2px solid var(--c-primary);outline-offset:-2px}.th--sorted{color:var(--c-primary)}.th__label{display:inline-flex;align-items:center;gap:6px}.th__label--end{width:100%;justify-content:flex-end}.th__sort{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;color:currentColor;line-height:1}.table tbody tr{transition:background .12s}.table tbody tr:hover{background:var(--c-surface-alt)}.table tbody tr:last-child td{border-bottom:0}.table .num{text-align:center;font-variant-numeric:tabular-nums}.cell-primary{font-weight:600;color:var(--c-text);text-align:inherit}.cell-secondary{font-size:12px;color:var(--c-text-subtle);margin-top:2px;text-align:inherit}.row-actions{display:flex;gap:6px;justify-content:flex-end}.empty{text-align:center;color:var(--c-text-subtle);padding:36px!important;font-size:13px}.total-label{text-align:right;font-weight:600;color:var(--c-text-muted)}.total-value{font-size:16px;font-weight:700;color:var(--c-text)}.table-scroll{max-height:540px;overflow-y:auto;overflow-x:auto}.pagination{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 18px;border-top:1px solid var(--c-border);background:var(--c-surface-alt);font-size:12.5px;color:var(--c-text-muted);gap:8px}.pagination__pages{display:flex;gap:6px;align-items:center}.pagination__btn{border:1px solid var(--c-border-strong);background:#fff;color:var(--c-text-muted);padding:6px 11px;border-radius:6px;cursor:pointer;font-size:12.5px;transition:background .15s,color .15s}.pagination__btn:hover:not(:disabled){background:var(--c-surface-hover);color:var(--c-text)}.pagination__btn:disabled{opacity:.45;cursor:not-allowed}.hist-pagination{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--c-text-muted);font-weight:500;white-space:nowrap}.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;letter-spacing:.01em}.tag--in{background:var(--c-success-soft);color:var(--c-success)}.tag--out{background:var(--c-danger-soft);color:var(--c-danger)}.chip{display:inline-block;padding:3px 9px;border-radius:6px;font-size:12px;background:var(--c-primary-softer);color:var(--c-primary);font-weight:500}.stock-pill{display:inline-block;min-width:56px;padding:5px 14px;border-radius:999px;background:var(--c-success-soft);border:1px solid transparent;font-weight:600;color:var(--c-success);text-align:center;font-variant-numeric:tabular-nums;font-size:12.5px}.stock-pill--low{background:var(--c-danger-soft);color:var(--c-danger)}.stock-pill--zero{background:#f0f1f5;color:var(--c-text-muted)}.alert{border-radius:var(--radius-sm);padding:12px 14px;font-size:13px;font-weight:500;border:1px solid transparent;display:flex;align-items:center;gap:10px;animation:fadeSlide .3s var(--ease-soft)}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.alert--error{background:var(--c-danger-soft);color:var(--c-danger-hover);border-color:#d92d2033}.alert--success{background:var(--c-success-soft);color:var(--c-success);border-color:#06764733}.alert--info{background:var(--c-info-soft);color:var(--c-primary);border-color:#2c5cff33}.segmented{display:inline-flex;border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);overflow:hidden;background:var(--c-surface);height:38px;box-shadow:var(--c-shadow-xs)}.segmented__btn{border:0;background:transparent;padding:0 14px;font:inherit;font-size:13px;font-weight:500;color:var(--c-text-muted);cursor:pointer;border-right:1px solid var(--c-border);transition:background .15s,color .15s}.segmented__btn:last-child{border-right:0}.segmented__btn:hover:not(.segmented__btn--active){background:var(--c-surface-alt);color:var(--c-text)}.segmented__btn--active{background:linear-gradient(180deg,#356bff,var(--c-primary));color:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.kpi-grid--dashboard{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.kpi-grid--inline{padding:16px 20px;border-bottom:1px solid var(--c-border);background:var(--c-surface)}.kpi{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--c-shadow-sm);padding:18px 20px;position:relative;overflow:hidden;transition:transform .18s var(--ease-soft),box-shadow .18s var(--ease-soft)}.kpi:hover{transform:translateY(-2px);box-shadow:var(--c-shadow-lg)}.kpi:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--c-border-strong);transition:background .2s}.kpi--primary:before{background:linear-gradient(180deg,#6e8bff,var(--c-primary))}.kpi--success:before{background:linear-gradient(180deg,#2bb673,var(--c-success))}.kpi--danger:before{background:linear-gradient(180deg,#ff7b6f,var(--c-danger))}.kpi--warning:before{background:linear-gradient(180deg,#fbbf24,var(--c-warning))}.kpi--muted:before{background:var(--c-text-subtle)}.kpi__top{display:flex;align-items:center;justify-content:space-between;gap:12px}.kpi__icon{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;background:var(--c-primary-softer);color:var(--c-primary)}.kpi--success .kpi__icon{background:var(--c-success-soft);color:var(--c-success)}.kpi--danger .kpi__icon{background:var(--c-danger-soft);color:var(--c-danger)}.kpi--warning .kpi__icon{background:var(--c-warning-soft);color:var(--c-warning)}.kpi--muted .kpi__icon{background:var(--c-surface-alt);color:var(--c-text-muted)}.kpi__label{color:var(--c-text-muted);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.kpi__value{font-size:26px;font-weight:700;margin-top:8px;font-variant-numeric:tabular-nums;letter-spacing:-.02em;min-height:30px}.kpi__hint{color:var(--c-text-subtle);font-size:12px;margin-top:6px}.kpi__skeleton{display:inline-block;width:70%;height:22px;background:linear-gradient(90deg,#eef0f4,#f7f8fb,#eef0f4);background-size:200% 100%;border-radius:4px;animation:shimmer 1.2s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:60;padding:20px;animation:fadeIn .16s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--c-surface);border-radius:var(--radius);width:min(560px,100%);max-height:90vh;overflow:auto;box-shadow:var(--c-shadow-xl);animation:popIn .2s var(--ease-spring);border:1px solid var(--c-border)}.modal--lg{width:min(820px,100%)}@keyframes popIn{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--c-border)}.modal__body{padding:22px}.modal__footer{padding:14px 22px;border-top:1px solid var(--c-border);background:var(--c-surface-alt);display:flex;justify-content:flex-end;gap:10px}.modal__close{border:0;background:transparent;font-size:22px;color:var(--c-text-muted);cursor:pointer;line-height:1;width:32px;height:32px;display:grid;place-items:center;border-radius:8px}.modal__close:hover{color:var(--c-text);background:var(--c-surface-alt)}.confirm-message{color:var(--c-text);font-size:14px;line-height:1.55}.login-page{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(900px 700px at -5% -10%,rgba(44,92,255,.1),transparent 60%),radial-gradient(700px 600px at 105% 105%,rgba(139,92,246,.09),transparent 55%),linear-gradient(160deg,#f6f8ff,#eef2ff,#f2eeff 70%,#fdf8ff);padding:24px;position:relative;overflow:hidden}.login-page__deco{position:absolute;border-radius:50%;pointer-events:none;z-index:0}.login-page__deco--1{width:700px;height:700px;background:radial-gradient(circle,rgba(44,92,255,.07) 0%,transparent 70%);top:-200px;left:-200px}.login-page__deco--2{width:600px;height:600px;background:radial-gradient(circle,rgba(139,92,246,.06) 0%,transparent 70%);bottom:-150px;right:-150px}.login-shell{flex:1;display:grid;place-items:center;width:100%;position:relative;z-index:2}.login-page>.footer{position:relative;z-index:2}.login-card{background:#fff;padding:44px 40px;border-radius:24px;border:1px solid rgba(44,92,255,.1);box-shadow:0 24px 64px #2c5cff24,0 4px 16px #2c5cff0f,0 0 0 1px #2c5cff08 inset;width:min(440px,100%);display:flex;flex-direction:column;gap:20px;animation:popIn .4s var(--ease-spring)}.login-card__brand{display:flex;flex-direction:column;align-items:center;gap:0;margin-bottom:4px;text-align:center}.login-card__logo{width:160px;height:160px;border-radius:32px;object-fit:cover;box-shadow:0 24px 56px -10px #2c5cff80,0 0 0 3px #fff,0 0 0 6px #2c5cff1a;animation:brandFloat 4s ease-in-out infinite}@keyframes brandFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.login-card__welcome{text-align:center}.login-card__welcome h2{font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--c-text)}.login-card__welcome p{margin-top:4px;color:var(--c-text-muted);font-size:13px}.login-card__hint{text-align:center;color:var(--c-text-subtle);font-size:12px}.login-card__hint code{background:var(--c-primary-softer);border-color:var(--c-primary-soft);color:var(--c-primary)}.login-input-group{position:relative;display:flex}.login-input-group .input{padding-left:38px}.login-input-group:has(.login-input-group__eye) .input{padding-right:40px}.login-input-group__icon{position:absolute;top:50%;left:12px;transform:translateY(-50%);color:var(--c-text-subtle);pointer-events:none;display:grid;place-items:center}.login-input-group__eye{position:absolute;top:50%;right:10px;transform:translateY(-50%);background:none;border:none;padding:4px;cursor:pointer;color:var(--c-text-subtle);display:grid;place-items:center;border-radius:4px;transition:color .15s,background .15s}.login-input-group__eye:hover{color:var(--c-text);background:var(--c-hover)}.footer{padding:18px 32px;text-align:center;font-size:12px;color:var(--c-text-muted);border-top:1px solid var(--c-border);background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;gap:6px}.footer a{color:var(--c-primary);font-weight:600;text-decoration:none;position:relative}.footer a:after{content:"";position:absolute;left:0;right:100%;bottom:-1px;height:1px;background:var(--c-primary);transition:right .25s var(--ease-soft)}.footer a:hover:after{right:0}.footer--dark{background:transparent;border-color:#ffffff0f;color:#ffffff8c}.footer--dark a{color:#b0c4ff}.footer--dark a:after{background:#b0c4ff}.product-search{position:relative;flex:1;min-width:0}.product-search__input{font-size:15px;padding:12px 14px;height:46px}.product-search__input-wrap{position:relative;display:flex;align-items:stretch;gap:8px}.product-search__list{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-sm);box-shadow:var(--c-shadow-lg);list-style:none;padding:4px;margin:0;z-index:10;max-height:300px;overflow-y:auto;animation:popIn .16s var(--ease-soft)}.product-search__item{padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .12s}.product-search__item--active{background:var(--c-primary-softer)}.product-search__name{font-weight:600;color:var(--c-text)}.product-search__meta{font-size:12px;color:var(--c-text-subtle);margin-top:2px}.purchase-toolbar{display:flex;gap:12px;padding:16px 20px;border-bottom:1px solid var(--c-border);background:var(--c-surface-alt);align-items:center;flex-wrap:wrap}.purchase-toolbar__ref{max-width:280px}.modal--scanner{width:min(560px,100%)}@media (max-width: 960px){.modal-overlay:has(.modal--scanner){padding:0!important;align-items:stretch!important}.modal--scanner{width:100%!important;max-height:100dvh!important;height:100dvh!important;border-radius:0!important;display:flex;flex-direction:column;animation:none!important}.modal--scanner .modal__body{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0}.modal--scanner .scanner{flex:1;aspect-ratio:unset!important;border-radius:0;margin-bottom:0;box-shadow:none}.modal--scanner .scanner__overlay,.modal--scanner .scanner__frame{display:none}.modal--scanner .scanner__hint{bottom:80px;font-size:14px;font-weight:600;background:#00000073;margin:0 20px;padding:8px 14px;border-radius:20px}.modal--scanner .scanner__line{top:50%;left:5%;right:5%}.modal--scanner .modal__header{position:absolute;top:0;left:0;right:0;z-index:10;background:linear-gradient(180deg,rgba(0,0,0,.65) 0%,transparent 100%);border-bottom:none;padding:14px 18px}.modal--scanner .modal__header h3{color:#fff}.modal--scanner .modal__close{color:#ffffffd9}.modal--scanner .modal__close:hover{background:#ffffff26;color:#fff}.modal--scanner .scanner__manual{position:absolute;bottom:0;left:0;right:0;padding:14px 16px calc(14px + env(safe-area-inset-bottom));background:linear-gradient(0deg,rgba(0,0,0,.75) 0%,transparent 100%)}}.scanner{position:relative;width:100%;aspect-ratio:4 / 3;background:#0a1020;border-radius:var(--radius);overflow:hidden;box-shadow:0 12px 30px #0f172a2e;margin-bottom:14px}.scanner__video{width:100%;height:100%;object-fit:cover;image-rendering:-webkit-optimize-contrast}.scanner__overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:grid;place-items:center}.scanner__frame{width:70%;height:50%;border:2px solid rgba(255,255,255,.7);border-radius:14px;box-shadow:0 0 0 9999px #080c1e8c}.scanner__hint{position:absolute;bottom:12px;left:0;right:0;text-align:center;color:#ffffffd9;font-size:12px;text-shadow:0 1px 4px rgba(0,0,0,.5)}.scanner__manual{padding-top:8px}.scanner__error{padding:18px;text-align:center;color:var(--c-danger);background:var(--c-danger-soft);border-radius:var(--radius)}.scanner__line{position:absolute;left:18%;right:18%;top:50%;height:2px;background:linear-gradient(90deg,transparent,var(--c-brand-2),transparent);box-shadow:0 0 16px var(--c-brand-2);animation:scanLine 2.4s ease-in-out infinite}@keyframes scanLine{0%,to{top:28%}50%{top:72%}}.dashboard-filters{gap:12px;flex-wrap:wrap}.kpi__change{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:999px;font-size:11.5px;font-weight:700;margin-top:8px;width:fit-content;letter-spacing:.01em}.kpi__change--up{background:var(--c-success-soft);color:var(--c-success)}.kpi__change--down{background:var(--c-danger-soft);color:var(--c-danger)}a.kpi,.kpi--clickable{text-decoration:none;color:inherit;display:block;cursor:pointer}a.kpi:hover,.kpi--clickable:hover{transform:translateY(-3px);box-shadow:var(--c-shadow-lg)}.dashboard-grid--charts{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;align-items:stretch}@media (max-width: 1100px){.dashboard-grid--charts{grid-template-columns:1fr}}.dashboard-grid--tables{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:stretch}.dashboard-grid--tables>*{min-width:0}@media (max-width: 960px){.dashboard-grid--tables{grid-template-columns:1fr}}.dash-empty{padding:36px 20px;text-align:center;color:var(--c-text-subtle);font-size:13px}.dash-skeleton{padding:8px 16px;display:flex;flex-direction:column;gap:10px}.dash-skeleton__row{display:flex;gap:12px;align-items:center;padding:10px 4px;border-bottom:1px solid var(--c-border)}.dash-skeleton__cell{height:14px;border-radius:4px;background:linear-gradient(90deg,#eef0f4,#f7f8fb,#eef0f4);background-size:200% 100%;animation:shimmer 1.2s infinite;flex-shrink:0}.date-range{display:flex;align-items:center;gap:6px;padding:2px 10px;border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);background:#fff;height:38px;width:100%}.date-range input{border:0;padding:0;height:auto;background:transparent;font-size:13px;min-width:0;flex:1}.date-range input:focus{box-shadow:none}.date-range__sep{color:var(--c-text-subtle);font-size:12px;flex-shrink:0}.dashboard-grid{display:grid;grid-template-columns:2fr 1.2fr;gap:16px;align-items:stretch}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr}}.chart-card{display:flex;flex-direction:column}.chart-card__header{padding:18px 20px;border-bottom:1px solid var(--c-border);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.chart-card__body{padding:20px;flex:1;display:flex;flex-direction:column;min-height:0}.chart-empty{color:var(--c-text-subtle);text-align:center;padding:60px 0;font-size:13.5px}.chart-wrap{width:100%;flex:1;min-height:280px;position:relative}.chart-svg{width:100%;height:100%;display:block}.low-stock-card{display:flex;align-items:center;gap:16px;padding:18px 22px;text-decoration:none;color:inherit;border-left:4px solid var(--c-warning);background:linear-gradient(90deg,var(--c-warning-soft),var(--c-surface) 65%);cursor:pointer;transition:transform .18s var(--ease-soft),box-shadow .2s var(--ease-soft),border-color .2s}.low-stock-card:hover{transform:translateY(-2px);box-shadow:var(--c-shadow-lg);border-left-color:#d97706}.low-stock-card__icon{width:46px;height:46px;border-radius:12px;background:var(--c-warning);color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:0 6px 16px #b547084d}.low-stock-card__body{flex:1;min-width:0}.low-stock-card__title{font-weight:700;color:var(--c-warning);font-size:14.5px;letter-spacing:-.01em}.low-stock-card__list{margin-top:4px;color:var(--c-text-muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.low-stock-card__action{display:inline-flex;align-items:center;gap:4px;color:var(--c-warning);font-weight:600;font-size:13px;white-space:nowrap;flex-shrink:0}.low-stock-card:hover .low-stock-card__action{transform:translate(2px);transition:transform .18s var(--ease-soft)}@media (max-width: 540px){.low-stock-card{flex-wrap:wrap;padding:14px 16px}.low-stock-card__list{white-space:normal}}.top-products{display:flex;flex-direction:column;gap:16px}.top-products__row{display:flex;flex-direction:column;gap:6px}.top-products__meta{display:flex;justify-content:space-between;font-size:13px;gap:12px}.top-products__name{font-weight:600;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:8px}.top-products__rank{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:6px;background:var(--c-primary-softer);color:var(--c-primary);font-weight:700;font-size:11px;flex-shrink:0}.top-products__qty{color:var(--c-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap}.top-products__bar{width:100%;height:8px;background:var(--c-surface-alt);border-radius:999px;overflow:hidden}.top-products__fill{height:100%;background:linear-gradient(90deg,#6e8bff,var(--c-primary));border-radius:999px;transition:width .6s var(--ease-soft);box-shadow:0 0 12px #2c5cff59}.settings-grid{display:grid;grid-template-columns:1fr;gap:16px}.settings-section__title{display:flex;align-items:center;gap:10px}.settings-section__title-icon{width:32px;height:32px;border-radius:8px;background:var(--c-primary-softer);color:var(--c-primary);display:grid;place-items:center}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.report-card{padding:20px;display:flex;flex-direction:column;gap:10px;border-left:4px solid var(--c-primary)}.report-card__title{font-weight:600;font-size:15px}.report-card__desc{color:var(--c-text-muted);font-size:13px;line-height:1.5;flex:1}.report-card__actions{display:flex;gap:8px;flex-wrap:wrap}@media (max-width: 960px){.sidebar{width:280px;transform:translate(-100%);transition:transform .3s var(--ease-soft);box-shadow:0 24px 48px #0000004d}.sidebar--open{transform:translate(0)}.sidebar__close-mobile{display:grid}.app-content{margin-left:0}.app-main{padding:18px 16px 24px}.topbar{display:flex}.sidebar-backdrop--open{display:block}.footer{padding:14px 18px}.form-grid{grid-template-columns:1fr}.field--col-2,.form-grid__footer{grid-column:auto}.filters-bar{grid-template-columns:1fr}.filters-bar__clear{justify-self:stretch}.page__header{gap:12px}.page__actions{width:100%}.input--num{width:86px}.table th,.table td{padding:11px 12px}.purchase-toolbar{padding:12px 14px;flex-wrap:wrap}.purchase-toolbar__ref{max-width:100%}.kpi{padding:14px 16px}.kpi__value{font-size:22px}.kpi-grid{gap:10px}.page{gap:16px}.modal-overlay{padding:12px}.table thead th:first-child,.table tbody td:first-child{position:sticky;left:0;z-index:2;box-shadow:2px 0 4px #0f172a0f}.table thead th:first-child{background:var(--c-surface-alt);z-index:3}.table tbody td:first-child{background:var(--c-surface)}.table tbody tr:hover td:first-child{background:var(--c-surface-alt)}}@media (max-width: 540px){h1{font-size:20px}.page{gap:12px}.app-main{padding:12px 12px 20px}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:20px 20px 0 0;width:100%;max-height:92vh;animation:slideUp .28s var(--ease-soft)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}.modal__header,.modal__body{padding:16px 18px}.modal__footer{padding:12px 18px}.kpi-grid,.kpi-grid--dashboard{grid-template-columns:1fr 1fr;gap:8px}.kpi{padding:12px}.kpi__value{font-size:18px;min-height:auto}.kpi__label{font-size:10px}.kpi__hint{font-size:11px}.card__header,.card__body{padding:12px 14px}.filters-bar{padding:12px 14px;gap:8px}.table th,.table td{padding:9px 10px;font-size:13px}.reports-grid{grid-template-columns:1fr}.purchase-toolbar{flex-direction:column;align-items:stretch;gap:8px}.login-page{padding:16px}.page__header{flex-direction:column;align-items:flex-start;gap:8px}.page__actions .btn{justify-content:center}.page__footer-actions{flex-direction:column}.page__footer-actions .btn{width:100%;justify-content:center}.form-grid__footer{flex-direction:column}.form-grid__footer .btn{width:100%;justify-content:center}.chart-card__header{padding:12px 14px;gap:8px}.scanner{aspect-ratio:3 / 4}.segmented{flex-wrap:wrap;height:auto;overflow:visible;padding:3px;gap:2px;background:var(--c-surface-alt)}.segmented__btn{flex:1;min-width:calc(33.333% - 3px);height:34px;border-right:0;border-radius:var(--radius-xs);padding:0 8px;font-size:12px}.segmented__btn--active{border-radius:var(--radius-xs)}.filters-bar--reports .segmented{width:100%}.filters-bar--reports .segmented .segmented__btn{flex:1;min-width:calc(33.333% - 3px)}.tag__arrow{display:none}}.drp{position:relative}.drp__btn{display:flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid var(--c-border-strong);border-radius:var(--radius-sm);background:var(--c-surface-alt);cursor:pointer;font:inherit;font-size:13.5px;color:var(--c-text);transition:border-color .15s,box-shadow .15s;height:38px;width:100%}.drp__btn:hover,.drp__btn--open{border-color:var(--c-primary);box-shadow:0 0 0 3px #2c5cff1a}.drp__btn--disabled{opacity:.45;cursor:not-allowed}.drp__range{display:flex;align-items:center;gap:8px;flex:1}.drp__date{font-variant-numeric:tabular-nums}.drp__arrow{color:var(--c-text-subtle)}.drp__caret{color:var(--c-text-subtle);font-size:11px}.drp__popover{position:absolute;top:calc(100% + 6px);left:0;z-index:200;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--c-shadow-lg);padding:14px;width:280px;animation:popIn .16s var(--ease-soft)}.drp__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.drp__month-label{font-weight:600;font-size:14px;color:var(--c-text)}.drp__nav{border:0;background:transparent;cursor:pointer;font-size:20px;color:var(--c-text-muted);padding:2px 8px;border-radius:6px;line-height:1;transition:background .12s,color .12s}.drp__nav:hover{background:var(--c-surface-alt);color:var(--c-text)}.drp__hint{font-size:11px;color:var(--c-primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;text-align:center}.drp__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.drp__day-name{text-align:center;font-size:10px;font-weight:700;color:var(--c-text-subtle);text-transform:uppercase;padding:4px 0;letter-spacing:.03em}.drp__day{border:0;background:transparent;border-radius:5px;cursor:pointer;font:inherit;font-size:12px;color:var(--c-text);padding:0;height:30px;width:100%;display:grid;place-items:center;transition:background .1s,color .1s}.drp__day:hover:not(:disabled){background:var(--c-primary-softer);color:var(--c-primary)}.drp__day--start,.drp__day--end{background:var(--c-primary);color:#fff;font-weight:700}.drp__day--range{background:var(--c-primary-softer);color:var(--c-primary);border-radius:0}.drp__day--start{border-radius:5px 0 0 5px}.drp__day--end{border-radius:0 5px 5px 0}.drp__day--start.drp__day--end{border-radius:5px}.drp__day--today:not(.drp__day--start):not(.drp__day--end){font-weight:700;color:var(--c-primary)}.drp__day--disabled{opacity:.28;cursor:not-allowed}.drp__day--empty{background:transparent;cursor:default;pointer-events:none}.stock-cat{display:flex;flex-direction:column;gap:14px;padding:4px 0}.stock-cat__row{display:grid;grid-template-columns:110px 1fr 100px 46px;align-items:center;gap:10px}.stock-cat__label{font-size:13px;font-weight:500;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stock-cat__bar-wrap{height:12px;background:var(--c-surface-alt);border-radius:999px;overflow:hidden}.stock-cat__bar{height:100%;border-radius:999px;transition:width .6s var(--ease-soft);animation:barReveal .6s var(--ease-soft) both}@keyframes barReveal{0%{width:0!important}}.stock-cat__value{font-size:13px;font-variant-numeric:tabular-nums;text-align:right;color:var(--c-text);font-weight:500}.stock-cat__pct{font-size:12px;font-weight:600;text-align:right}@media (max-width: 540px){.stock-cat__row{grid-template-columns:80px 1fr 80px 40px;gap:6px}}.chart-toggle-btn{border:1px solid var(--c-border-strong);background:#fff;color:var(--c-text-muted);border-radius:6px;cursor:pointer;font-size:14px;padding:4px 10px;line-height:1;transition:background .12s,color .12s,border-color .12s}.chart-toggle-btn:hover{background:var(--c-surface-alt);color:var(--c-text)}.chart-toggle-btn--active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.drp-back-btn{border:0;background:transparent;color:var(--c-primary);font:inherit;font-size:12.5px;cursor:pointer;padding:0;font-weight:600}.drp-back-btn:hover{text-decoration:underline}.chart-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e1726a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:80;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .18s ease-out}.chart-modal{background:var(--c-surface);border-radius:var(--radius);width:min(1160px,100%);max-height:92vh;display:flex;flex-direction:column;box-shadow:var(--c-shadow-xl);border:1px solid var(--c-border);animation:popIn .22s var(--ease-spring);overflow:hidden}.chart-modal__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--c-border);flex-shrink:0;background:var(--c-surface-alt)}.chart-modal__header h3{font-size:16px}.chart-modal__body{flex:1;padding:24px;overflow:auto;min-height:0}.chart-expand-btn{border:1px solid var(--c-border-strong);background:#fff;color:var(--c-text-muted);border-radius:7px;cursor:pointer;padding:5px 8px;line-height:1;transition:background .12s,color .12s,border-color .12s;display:inline-flex;align-items:center;justify-content:center}.chart-expand-btn:hover{background:var(--c-primary-softer);color:var(--c-primary);border-color:var(--c-primary-soft)}.chart-card__controls{display:flex;align-items:center;gap:6px}.apex-range-label{text-align:right;font-size:11px;color:#b0bac8;font-style:italic;margin-top:-4px;padding-right:8px;padding-bottom:4px}.apex-drillable .apexcharts-bar-series .apexcharts-bar-area{cursor:pointer}.apex-drillable .apexcharts-series path{cursor:pointer}.filters-bar .segmented{width:100%;display:flex}.filters-bar .segmented .segmented__btn{flex:1;justify-content:center}.filters-bar--movements{grid-template-columns:auto auto;justify-content:start;gap:16px}.filters-bar__date-clear{display:flex;align-items:flex-end;gap:8px;width:auto}.filters-bar__date-clear .filters-bar__clear{align-self:flex-end}@media (max-width: 960px){.filters-bar--movements{grid-template-columns:1fr}.filters-bar__date-clear{flex-direction:column;align-items:stretch}.filters-bar__date-clear .field{min-width:0}.filters-bar__date-clear .filters-bar__clear{width:100%}}.apexcharts-tooltip{border-radius:10px!important;box-shadow:0 8px 24px #0f172a38!important}.apexcharts-tooltip-title{font-size:11px!important;border-radius:10px 10px 0 0!important}.apexcharts-xaxistooltip{display:none!important}.login-page .footer{background:#ffffff80;border-color:#2c5cff14;color:var(--c-text-subtle)}@media (max-width: 540px){.login-card{padding:32px 24px}.login-card__logo{width:130px;height:130px}}.chart-modal__subtitle{font-size:12.5px;color:var(--c-text-muted);margin-top:3px}.chart-modal__close-btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--c-border-strong);background:#fff;color:var(--c-text-muted);padding:8px 14px;border-radius:var(--radius-sm);font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .14s,color .14s,border-color .14s;white-space:nowrap}.chart-modal__close-btn:hover{background:var(--c-danger-soft);border-color:#d92d204d;color:var(--c-danger)}.chart-card{overflow:visible}.chart-card>.chart-card__header{border-radius:var(--radius) var(--radius) 0 0;overflow:hidden}.chart-card>.chart-card__body{border-radius:0 0 var(--radius) var(--radius);overflow:hidden;min-height:340px}.dashboard-grid--charts{align-items:start}.dashboard-grid--charts .chart-card>.chart-card__body{height:360px;flex:none;overflow:hidden;overflow-y:auto}.dashboard-grid--charts .chart-card>.chart-card__body--scroll{overflow-y:auto}.drp--sm .drp__btn{height:34px;padding:5px 10px;font-size:12.5px}.drp--sm .drp__range{gap:5px}.drp--sm .drp__date{font-size:12px}.filters-bar--reports{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;width:fit-content;max-width:100%}.filters-bar--reports .field{min-width:0}.filters-bar--reports .segmented{width:auto}.filters-bar--reports .segmented .segmented__btn{flex:none;min-width:80px}.stock-total-value{font-size:20px;font-weight:700;color:var(--c-primary);letter-spacing:-.02em;margin-top:2px;line-height:1.2}.chart-header-range{font-size:12px;color:var(--c-text-muted);margin-top:2px;font-weight:500}.settings-cat-form{padding:16px 20px;border-bottom:1px solid var(--c-border);background:var(--c-surface-alt)}.settings-cat-form__row{display:flex;gap:12px;align-items:flex-end}.settings-cat-form__input{flex:1;min-width:0}.settings-cat-form__btn{flex-shrink:0;align-self:flex-end;height:38px}.mobile-only{display:none}@media (max-width: 960px){.mobile-only{display:block}.desktop-only{display:none!important}}.chart-card>.chart-card__body.chart-card__body--auto{min-height:0;height:auto;flex:0 0 auto}.dashboard-grid--charts .chart-card>.chart-card__body.chart-card__body--table{height:auto;min-height:0;max-height:380px;overflow-y:auto;flex:0 0 auto}@media (max-width: 960px){.chart-card>.chart-card__body{height:auto!important;min-height:0!important}.chart-card{overflow:hidden}}.dashboard-grid--charts>*{min-width:0}.top-products__name-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 540px){.btn-label{display:none}.row-actions .btn--sm{padding:5px 7px}}@media (max-width: 720px){.card__header--hist{flex-direction:column;align-items:stretch;gap:4px}.card__header--hist .hist-pagination{justify-content:center;padding-top:10px;border-top:1px solid var(--c-border)}}
