:root{--bg-from: #ddeeff;--bg-mid: #eae8f8;--bg-to: #f8eaf0;--glass-bg: rgba(255, 255, 255, .88);--glass-bg-hover: rgba(255, 255, 255, .96);--glass-border: rgba(180, 200, 230, .4);--glass-shadow: 0 2px 12px rgba(80, 100, 170, .07);--glass-blur: blur(20px) saturate(160%);--glass-radius: 14px;--accent: #5b6fee;--accent-dim: rgba(91, 111, 238, .12);--accent-hover: #6b7ff5;--green: #16a34a;--green-dim: rgba(22, 163, 74, .12);--amber: #d97706;--amber-dim: rgba(217, 119, 6, .12);--red: #dc2626;--red-dim: rgba(220, 38, 38, .12);--blue: #2563eb;--blue-dim: rgba(37, 99, 235, .12);--text-primary: #1e2340;--text-secondary: #4a5280;--text-muted: #8892b0;--font: "Inter", system-ui, sans-serif;--transition: .18s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;min-height:100vh;font-family:var(--font);color:var(--text-primary)}html{background:linear-gradient(145deg,var(--bg-from) 0%,var(--bg-mid) 50%,var(--bg-to) 100%);background-attachment:fixed}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#5b6fee40;border-radius:3px}.glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--glass-radius);box-shadow:var(--glass-shadow)}.glass-card{composes:glass;padding:1.5rem}.product-card{cursor:pointer;transition:box-shadow .18s ease,transform .18s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;outline:none}.product-card:hover{box-shadow:0 4px 20px #5b6fee33;transform:translateY(-2px)}.product-card:active{transform:scale(.96);box-shadow:var(--glass-shadow)}.product-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.product-card__name{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-weight:600;font-size:.72rem;line-height:1.3;color:var(--text-primary)}.filter-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;max-height:260px;overflow-y:auto;background:#fff;border:1px solid rgba(180,200,230,.55);border-radius:10px;box-shadow:0 8px 24px #5064aa2e;z-index:200;padding:.35rem;display:flex;flex-direction:column;gap:2px}.filter-dropdown__item{width:100%;text-align:left;background:none;border:none;border-radius:7px;padding:.3rem .55rem;font-size:.76rem;color:var(--text-primary);cursor:pointer;transition:background .12s}.filter-dropdown__item:hover{background:#5b6fee14}.filter-dropdown__item--active{background:var(--accent, #5b6fee);color:#fff;font-weight:600}[role=button]:hover .img-upload-overlay,[role=button]:focus-visible .img-upload-overlay{opacity:1!important}.app-layout{display:grid;grid-template-rows:64px 1fr;min-height:100vh}.navbar{display:flex;align-items:center;gap:1rem;padding:0 1.5rem;background:#0d0d1ab3;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--glass-border);position:sticky;top:0;z-index:100}.navbar-brand{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.navbar-spacer{flex:1}.main-content{padding:1.75rem;overflow-y:auto}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:var(--transition);font-family:var(--font);white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#3b6fd4,#6b9fff);color:#fff;box-shadow:0 0 16px #3b6fd438}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4a7fe4,#7bafff);box-shadow:0 0 22px #3b6fd45c;transform:translateY(-1px)}.btn-ghost{background:var(--glass-bg);color:var(--text-secondary);border:1px solid var(--glass-border)}.btn-ghost:hover:not(:disabled){background:var(--glass-bg-hover);color:var(--text-primary)}.btn-danger{background:#ef444426;color:var(--red);border:1px solid rgba(239,68,68,.25)}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-xs{padding:.25rem .6rem;font-size:.75rem;border-radius:6px}.input{width:100%;background:#ffffffa6;border:1px solid rgba(160,180,220,.4);border-radius:8px;padding:.6rem .9rem;color:var(--text-primary);font-size:.9rem;font-family:var(--font);transition:var(--transition);outline:none}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent);background:#ffffffe6;box-shadow:0 0 0 3px #5b6fee29}.input-group{display:flex;flex-direction:column;gap:.4rem}.input-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%235b6fee' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.2rem;cursor:pointer}select.input:hover{border-color:#5b6fee61}input[type=date].input{cursor:pointer;color-scheme:light}input[type=date].input::-webkit-calendar-picker-indicator{opacity:.6;cursor:pointer;filter:invert(28%) sepia(80%) saturate(400%) hue-rotate(210deg)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:99px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.badge-green{background:var(--green-dim);color:var(--green)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-blue{background:var(--blue-dim);color:var(--blue)}.badge-violet{background:var(--accent-dim);color:var(--accent)}.badge-gray{background:#94a3b826;color:#94a3b8}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.875rem}.data-table th{text-align:left;padding:.65rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--glass-border)}.data-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(91,111,238,.08);vertical-align:middle;color:var(--text-primary)}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover td{background:#5b6fee0d}.data-table td.muted{color:var(--text-muted);font-size:.8rem}.data-table td.mono{font-family:Fira Mono,Consolas,monospace;font-size:.8rem;color:var(--text-secondary)}@media (max-width: 640px){.hide-mobile{display:none!important}.data-table th,.data-table td{padding:.4rem .3rem}}.conn-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.conn-dot.connected{background:var(--green);box-shadow:0 0 8px var(--green)}.conn-dot.connecting{background:var(--amber);animation:pulse 1.2s ease-in-out infinite}.conn-dot.disconnected{background:var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.section-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:999;display:flex;align-items:center;gap:.6rem;padding:.75rem 1.2rem;border-radius:10px;font-size:.875rem;font-weight:500;animation:slideUp .25s ease;max-width:360px}.toast-success{background:#34d39933;border:1px solid rgba(52,211,153,.35);color:var(--green)}.toast-error{background:var(--red-dim);border:1px solid rgba(248,113,113,.35);color:var(--red)}.toast-info{background:var(--blue-dim);border:1px solid rgba(96,165,250,.35);color:var(--blue)}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@keyframes cmd-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes cmd-card-in{0%{opacity:0;transform:scale(.88) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes cmd-spin{to{transform:rotate(360deg)}}@keyframes cmd-pop{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes cmd-progress{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleInCenter{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes dialogIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.branch-display{display:flex;align-items:center;gap:.5rem;padding:.28rem .5rem .28rem .75rem;border-radius:10px;border:1px solid var(--glass-border);background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:260px;min-width:0}.branch-display__name{font-size:.8rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.branch-display__change{font-size:.72rem;font-weight:600;flex-shrink:0;padding:.2rem .6rem;border-radius:6px;border:1px solid rgba(59,111,212,.25);background:#3b6fd412;color:var(--accent);cursor:pointer;transition:var(--transition);white-space:nowrap;line-height:1.6}.branch-display__change:hover{background:var(--accent-dim);border-color:#3b6fd459}.branch-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141c3c6b;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:500;animation:fadeIn .16s ease}.branch-modal__dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:501;width:min(420px,calc(100vw - 2rem));background:#fff;border-radius:1rem;box-shadow:0 12px 48px #283ca033;animation:dialogIn .18s ease forwards;overflow:hidden}.branch-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;background:linear-gradient(135deg,#d8e8ff,#f0e8ff);border-bottom:2px solid rgba(180,190,230,.55);font-weight:700;font-size:.95rem;color:#1e2340}.branch-modal__close{width:28px;height:28px;border-radius:7px;border:1px solid rgba(140,160,220,.5);background:#ffffffb3;color:#1e2340;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:var(--transition)}.branch-modal__close:hover{background:var(--red-dim);border-color:#f8717159;color:var(--red)}.branch-modal__body{padding:.75rem;display:flex;flex-direction:column;gap:.3rem;max-height:340px;overflow-y:auto}.branch-modal__item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:.6rem;border:1.5px solid transparent;background:transparent;cursor:pointer;text-align:left;width:100%;transition:var(--transition);color:var(--text-primary);font-family:inherit}.branch-modal__item:hover:not(.branch-modal__item--active){background:#5b6fee0f;border-color:#5b6fee1f}.branch-modal__item--active{background:var(--accent-dim);border-color:#3b6fd44d}.branch-modal__item-name{flex:1;font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.branch-modal__footer{display:flex;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--glass-border);background:#f5f7ffb3}.branch-switch-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0f143299;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.branch-switch-overlay__card{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:2.5rem 3rem;background:#fff;border-radius:1.25rem;box-shadow:0 12px 52px #283ca03d;animation:scaleInCenter .22s ease;text-align:center;min-width:220px}.branch-switch-overlay__title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.branch-switch-overlay__name{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-top:.3rem}.empty-state{padding:3rem 1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 56px);padding:2rem;text-align:center;gap:1rem}.not-found__code{font-size:6rem;font-weight:800;line-height:1;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;-webkit-user-select:none;user-select:none}.not-found__title{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.not-found__desc{font-size:.9rem;color:var(--text-muted);max-width:320px;line-height:1.6}@keyframes loginBgMorph{0%{background:linear-gradient(160deg,#d8e8ff,#eaf2ff 35%,#f0e8ff 65%,#e4f0ff)}to{background:linear-gradient(160deg,#dde4ff,#eeeaff 35%,#f5eaff 65%,#e8f0ff)}}@keyframes loginBlobA{0%{transform:translate(0);background:#6b9fff38}to{transform:translate(14px,14px);background:#a78bfa38}}@keyframes loginBlobB{0%{transform:translate(0);background:#a78bfa29}to{transform:translate(-14px,-14px);background:#60a5fa29}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:3rem 2.5rem;position:relative;overflow:hidden;background:linear-gradient(160deg,#d8e8ff,#eaf2ff 35%,#f0e8ff 65%,#e4f0ff);animation:loginBgMorph 9s ease-in-out infinite alternate;--accent: #3b6fd4;--accent-dim: rgba(59, 111, 212, .1);--glass-border: rgba(59, 111, 212, .18)}.login-page:before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;top:-120px;left:-120px;pointer-events:none;animation:loginBlobA 6s ease-in-out infinite alternate}.login-page:after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;bottom:-100px;right:-100px;pointer-events:none;animation:loginBlobB 6s ease-in-out infinite alternate}.login-card{width:100%;max-width:340px;padding:2.25rem 1.75rem;background:#f0f6ffc7;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border:1.5px solid rgba(255,255,255,.7);border-radius:var(--glass-radius);box-shadow:0 8px 40px #3b6fd41a,0 2px 8px #0000000f;position:relative;z-index:1}.login-logo{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:2rem}.login-logo-image{width:min(90px,100%);height:auto;object-fit:contain;display:block}.login-logo-title{font-size:1.02rem;font-weight:700;color:#1a1d2e;text-align:center}.login-logo-icon{width:52px;height:52px;background:linear-gradient(135deg,#3b6fd4,#6b9fff);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 0 28px #3b6fd459}.login-logo-name{font-size:1.3rem;font-weight:700;background:linear-gradient(135deg,#3b6fd4,#6b9fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo-sub{font-size:.78rem;color:#6b7280}.login-form{display:flex;flex-direction:column;gap:1.2rem}.login-page .input-label{color:#6b7280}.login-page .input{background:#ffffffb3;border-color:#3b6fd438;color:#1a1d2e}.login-page .input::placeholder{color:#9ca3af}.login-page .input:focus{border-color:#3b6fd4;background:#ffffffeb;box-shadow:0 0 0 3px #3b6fd42e}.login-page .btn-primary{background:linear-gradient(135deg,#3b6fd4,#6b9fff);box-shadow:0 0 18px #3b6fd452}.login-page .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4a7fe4,#7bafff);box-shadow:0 0 26px #3b6fd47a;transform:translateY(-1px)}.login-page .error-msg{background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:8px;padding:.6rem .9rem;font-size:.82rem;color:#ef4444}.error-msg{background:var(--red-dim);border:1px solid rgba(248,113,113,.3);border-radius:8px;padding:.6rem .9rem;font-size:.82rem;color:var(--red)}.dashboard-grid{display:grid;grid-template-columns:1fr 420px;gap:1.5rem;align-items:start}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr}}.branch-pill{display:flex;align-items:center;gap:.5rem;padding:.32rem .85rem;background:#ffffffbf;border:1.5px solid rgba(91,111,238,.22);border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-primary);font-family:var(--font);transition:var(--transition);box-shadow:0 1px 4px #5b6fee14}.branch-pill:hover{background:#fff;border-color:#5b6fee66;box-shadow:0 2px 8px #5b6fee24}select.branch-pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%235b6fee' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;background-color:#ffffffbf;padding-right:1.8rem;outline:none}select.branch-pill:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b6fee29;background-color:#fff}.scroll-panel{overflow-y:auto;max-height:420px}.gs-trigger--pill{display:inline-flex;align-items:center;gap:.5rem;padding:.32rem .75rem .32rem .85rem;background:#ffffffbf;border:1.5px solid rgba(91,111,238,.22);border-radius:10px;font-size:.85rem;font-weight:500;font-family:var(--font);color:var(--text-primary);cursor:pointer;outline:none;transition:var(--transition);box-shadow:0 1px 4px #5b6fee14;white-space:nowrap;max-width:260px}.gs-trigger--pill:hover{background:#fff;border-color:#5b6fee66;box-shadow:0 2px 8px #5b6fee24}.gs-trigger--pill:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b6fee29}.gs-trigger--sm{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .6rem .28rem .65rem;background:#ffffffb8;border:1.5px solid rgba(91,111,238,.2);border-radius:8px;font-size:.82rem;font-family:var(--font);color:var(--text-primary);cursor:pointer;outline:none;transition:var(--transition);white-space:nowrap}.gs-trigger--sm:hover{border-color:#5b6fee61;background:#fff}.gs-trigger--sm:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b6fee24}.gs-icon{display:flex;align-items:center;color:var(--accent);flex-shrink:0;transition:transform .18s ease}[data-state=open] .gs-icon{transform:rotate(180deg)}.gs-content{background:#f8f9fff7;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border:1px solid rgba(91,111,238,.16);border-radius:12px;box-shadow:0 8px 32px #5064aa1f,0 2px 8px #0000000f;overflow:hidden;z-index:200;min-width:var(--radix-select-trigger-width);transform-origin:var(--radix-select-content-transform-origin);animation:gsSlideIn .15s ease}@keyframes gsSlideIn{0%{opacity:0;transform:scaleY(.92) translateY(-4px)}to{opacity:1;transform:scaleY(1) translateY(0)}}.gs-viewport{padding:.3rem}.gs-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;font-family:var(--font);color:var(--text-primary);cursor:pointer;outline:none;transition:background .12s ease;-webkit-user-select:none;user-select:none}.gs-item[data-highlighted]{background:var(--accent-dim);color:var(--accent)}.gs-item[data-state=checked]{font-weight:600;color:var(--accent)}.gs-item-indicator{display:flex;align-items:center;color:var(--accent);flex-shrink:0}.select-sm{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffffb8;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath fill='none' stroke='%235b6fee' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4.5 4.5L10 1'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .55rem center;border:1.5px solid rgba(91,111,238,.2);border-radius:8px;padding:.3rem 1.7rem .3rem .65rem;font-size:.82rem;font-family:var(--font);color:var(--text-primary);cursor:pointer;outline:none;transition:var(--transition)}.select-sm:hover{border-color:#5b6fee61}.select-sm:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b6fee24;background-color:#fff}.date-sm{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffffb8;border:1.5px solid rgba(91,111,238,.2);border-radius:8px;padding:.3rem .65rem;font-size:.82rem;font-family:var(--font);color:var(--text-primary);cursor:pointer;outline:none;transition:var(--transition);color-scheme:light}.date-sm:hover{border-color:#5b6fee61}.date-sm:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b6fee24;background-color:#fff}.date-sm::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;filter:invert(28%) sepia(80%) saturate(400%) hue-rotate(210deg)}.cmd-form{display:flex;flex-direction:column;gap:.9rem}.cmd-fields-grid{display:grid;gap:.75rem}.cmd-row{position:relative}.nav-tab{padding:.3rem .75rem;border-radius:6px;font-size:.82rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border:1px solid transparent;transition:var(--transition)}.nav-tab:hover{background:var(--glass-bg);color:var(--text-primary)}.nav-tab-active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent-dim)}.page-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.app-shell{display:flex;min-height:100vh;position:relative}.sidebar{width:220px;min-width:220px;height:100vh;position:sticky;top:0;display:flex;flex-direction:column;background:#d2dcf5b8;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-right:1px solid rgba(150,170,215,.4);z-index:200;overflow:hidden}.sidebar__brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--glass-border)}.sidebar__brand-logo{width:36px;height:36px;object-fit:contain;flex-shrink:0;border-radius:8px}.sidebar__brand-text{display:flex;flex-direction:column;min-width:0}.sidebar__brand-name{font-size:.95rem;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__brand-sub{font-size:.68rem;color:var(--text-muted);white-space:nowrap}.sidebar__nav{flex:1;display:flex;flex-direction:column;gap:.25rem;padding:1rem .75rem;overflow-y:auto}.sidebar__nav-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .9rem;border-radius:9px;text-decoration:none;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:var(--transition);border:1px solid transparent}.sidebar__nav-item:hover{background:#5b6fee14;color:var(--text-primary)}.sidebar__nav-item--active{background:var(--accent-dim);color:var(--accent);border-color:#5b6fee40}.sidebar__nav-icon{display:flex;align-items:center;flex-shrink:0;opacity:.8}.sidebar__nav-item--active .sidebar__nav-icon{opacity:1}.sidebar__nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__footer{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;border-top:1px solid var(--glass-border)}.sidebar__user{display:flex;align-items:center;gap:.65rem}.sidebar__user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(91,111,238,.25);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--accent);flex-shrink:0}.sidebar__user-info{display:flex;flex-direction:column;min-width:0}.sidebar__user-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{font-size:.7rem;color:var(--text-muted)}.sidebar__logout{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:7px;background:transparent;border:1px solid var(--glass-border);color:var(--text-muted);font-size:.78rem;font-family:var(--font);cursor:pointer;transition:var(--transition);width:100%}.sidebar__logout:hover{background:var(--red-dim);border-color:#f871714d;color:var(--red)}.app-shell__main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}.app-shell__content{flex:1;padding:1.75rem;overflow-y:auto}.topbar{display:grid;grid-template-columns:40px 1fr 40px;align-items:center;padding:0 1rem;height:52px;min-height:52px;background:#cddaf5c7;backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);position:sticky;top:0;z-index:100;box-shadow:0 1px #8ca5d759;transition:box-shadow .25s ease}.topbar--scrolled{box-shadow:0 2px 16px #5064aa21}.topbar__brand{display:flex;align-items:center;justify-content:flex-start}.topbar__brand-logo{width:28px;height:28px;border-radius:7px;object-fit:cover;flex-shrink:0}.topbar__brand-letter{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,#3b6fd4,#6b9fff);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem;color:#fff;flex-shrink:0}.topbar__controls{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0}.topbar__center{display:flex;align-items:center;justify-content:center;min-width:0;overflow:hidden;padding:0 .25rem}.topbar__user{display:flex;align-items:center;gap:.5rem}.topbar__usermenu{position:relative}.topbar__avatar-btn{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);border:1.5px solid rgba(59,111,212,.3);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:500;color:var(--accent);cursor:pointer;transition:var(--transition);padding:0;flex-shrink:0}.topbar__avatar-btn:hover{background:#3b6fd42e;border-color:#3b6fd480}.user-menu{position:absolute;top:calc(100% + .5rem);right:0;width:230px;background:#fff;border:1px solid var(--glass-border);border-radius:.75rem;box-shadow:0 8px 32px #283ca024;z-index:300;overflow:hidden;animation:scaleInCenter .14s ease;transform-origin:top right}.user-menu__header{padding:.85rem 1rem .75rem;background:linear-gradient(135deg,#d8e8ff,#f0e8ff)}.user-menu__org{font-size:.88rem;font-weight:700;color:#1e2340;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu__name{font-size:.74rem;color:#5a6080;margin-top:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__divider{height:1px;background:var(--glass-border);margin:0}.user-menu__section-label{padding:.5rem 1rem .2rem;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.user-menu__status-row{display:flex;align-items:center;gap:.6rem;padding:.35rem 1rem .55rem;font-size:.8rem;color:var(--text-secondary)}.user-menu__branch-row{display:flex;align-items:center;gap:.6rem;padding:.35rem 1rem;font-size:.8rem;color:var(--text-secondary)}.user-menu__branch-row--active{background:#3b6fd40d;color:var(--text-primary)}.user-menu__branch-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__active-tag{font-size:.62rem;font-weight:700;padding:.1rem .4rem;border-radius:99px;background:var(--accent-dim);color:var(--accent);flex-shrink:0}.user-menu__switch-branch{display:flex;align-items:center;gap:.5rem;width:100%;padding:.55rem 1rem;background:transparent;border:none;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--accent);font-family:inherit;transition:var(--transition);margin-top:.25rem}.user-menu__switch-branch:hover{background:var(--accent-dim)}.user-menu__logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:.65rem 1rem;background:transparent;border:none;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--red);font-family:inherit;transition:var(--transition)}.user-menu__logout:hover{background:var(--red-dim)}.server-banner{display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.3rem 1rem;font-size:.74rem;font-weight:600;background:#ef44441a;color:var(--red);border-bottom:1px solid rgba(239,68,68,.22);animation:fadeIn .2s ease}.server-banner--connecting{background:#f59e0b1a;color:#92400e;border-bottom-color:#f59e0b40}.footbar{display:none;position:fixed;bottom:0;left:0;right:0;height:56px;background:#ffffffd1;backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-top:1px solid var(--glass-border);z-index:200;align-items:stretch}.footbar__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;text-decoration:none;color:var(--text-muted);font-size:.68rem;font-weight:500;transition:var(--transition);padding:.25rem 0;border-top:2px solid transparent}.footbar__item:hover{color:var(--text-secondary)}.footbar__item--active{color:var(--accent);border-top-color:var(--accent)}.footbar__icon{display:flex;align-items:center;justify-content:center}.footbar__label{line-height:1}.connection-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.28rem .65rem;border-radius:20px;background:#ffffffa6;border:1px solid rgba(91,111,238,.2);font-size:.75rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none}.connection-badge__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;transition:background-color .3s ease,box-shadow .3s ease}.connection-badge__dot--pulse{animation:dotPulse 2s ease-in-out infinite}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}.sales-section-label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.9rem}.sales-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1rem}.sales-payment-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.sales-split-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.sales-split-grid>.glass{min-width:0;overflow:hidden}.sales-filter-bar{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;margin-bottom:1rem;flex-wrap:wrap}.sales-filter-dates{display:flex;align-items:center;gap:.5rem}.sales-filter-shortcuts{display:flex;gap:.4rem;flex-wrap:wrap}.sales-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (min-width: 768px) and (max-width: 1100px){.sales-stat-grid,.sales-payment-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 767px){.sales-stat-grid,.sales-payment-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}.sales-split-grid{grid-template-columns:1fr}.sales-filter-bar{gap:.6rem;padding:.9rem 1rem}.sales-filter-dates{gap:.35rem}.sales-filter-dates .input{width:130px!important}}@media (min-width: 768px){.footbar{display:none!important}.app-shell__content{padding-bottom:1.75rem}.topbar__brand{display:none}.topbar{grid-template-columns:1fr 40px}}@media (max-width: 767px){.sidebar{display:none}.footbar{display:flex}.app-shell__content{padding-bottom:calc(56px + 1rem)}}.sync-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .6rem;border:none;background:transparent;cursor:pointer;border-radius:99px;transition:background .15s}.sync-toggle:disabled{opacity:.5;cursor:wait}.sync-toggle:not(:disabled):hover{background:#0000000d}.sync-toggle__track{position:relative;width:36px;height:20px;border-radius:99px;transition:background .2s;flex-shrink:0}.sync-toggle--on .sync-toggle__track{background:var(--green)}.sync-toggle--off .sync-toggle__track{background:#94a3b866}.sync-toggle__thumb{position:absolute;top:3px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:left .2s}.sync-toggle--on .sync-toggle__thumb{left:calc(100% - 17px)}.sync-toggle--off .sync-toggle__thumb{left:3px}.sync-toggle__label{font-size:.78rem;font-weight:600;min-width:6.5rem;text-align:left}.sync-toggle--on .sync-toggle__label{color:var(--green)}.sync-toggle--off .sync-toggle__label{color:var(--text-muted)}.inv-badge{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:700;line-height:1.2;white-space:nowrap}.inv-badge--ok{background:#22c55e26;color:#16a34a}.inv-badge--low{background:#f59e0b26;color:#d97706}.inv-badge--zero{background:#ef444426;color:#dc2626}.inv-badge--untracked{background:#94a3b81f;color:var(--text-muted);font-weight:500}.inv-mov-badge{display:inline-block;padding:.15rem .4rem;border-radius:.3rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.inv-mov-badge--entrada{background:#22c55e24;color:#16a34a}.inv-mov-badge--salida{background:#ef444424;color:#dc2626}.inv-mov-badge--ajuste{background:#6366f124;color:#6366f1}.inv-mov-badge--venta{background:#3b82f624;color:#2563eb}.inv-mov-badge--devolucion{background:#f59e0b24;color:#d97706}.inv-stat{padding:.55rem .85rem;border-left:3px solid var(--green);display:flex;flex-direction:column;gap:.1rem;min-width:80px}.inv-stat__value{font-size:1.15rem;font-weight:800;color:var(--text-primary)}.inv-stat__label{font-size:.68rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.inv-group-card{border-radius:.6rem;overflow:hidden;border:1px solid var(--glass-border)}.inv-group-card:hover{border-color:#8ca0dc73}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}
