:root{font-family:Plus Jakarta Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-size:var(--app-font-size-px, 16px);color-scheme:light dark;color:#0f1f2e;background-color:#e4efe8;--app-brand-navy: #0a3d66;--app-page-highlight: rgba(255, 213, 79, .14);--app-bg: #e4efe8;--app-surface: #f8fdfb;--app-border: #dfe6e3;--app-text: #0f1f2e;--app-text-muted: #5c6b73;--app-accent: #6abf4b;--app-accent-hover: #559e3a;--app-accent-light: #9ccc65;--app-accent-deep: #3f6d2c;--app-accent-bg: rgba(106, 191, 75, .14);--app-accent-alpha-10: rgba(106, 191, 75, .1);--app-accent-alpha-15: rgba(106, 191, 75, .15);--app-accent-alpha-20: rgba(106, 191, 75, .2);--app-accent-alpha-30: rgba(106, 191, 75, .3);--app-accent-alpha-35: rgba(106, 191, 75, .35);--app-input-bg: #ffffff;--app-input-border: #d5ddd9;--app-input-text: #0f1f2e;--app-shadow: rgba(10, 61, 102, .12);--app-sidebar-bg: #0a2740;--app-sidebar-text: #f0fdfa;--app-sidebar-text-muted: #9fb8c9;--app-sidebar-border: #143d5c;--app-sidebar-hover: #123351;--app-sidebar-active-bg: rgba(156, 204, 101, .22);--app-sidebar-expanded-width: 320px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{color:#f0fdfa;background-color:#081420;color-scheme:dark;--app-brand-navy: #8ecae6;--app-page-highlight: rgba(255, 213, 79, .1);--app-bg: #081420;--app-surface: #0f1f33;--app-border: #1e3a52;--app-text: #f0fdfa;--app-text-muted: #94a8b8;--app-accent: #9ccc65;--app-accent-hover: #aed581;--app-accent-light: #c5e1a5;--app-accent-deep: #7cb342;--app-accent-bg: rgba(156, 204, 101, .16);--app-accent-alpha-10: rgba(156, 204, 101, .12);--app-accent-alpha-15: rgba(156, 204, 101, .18);--app-accent-alpha-20: rgba(156, 204, 101, .24);--app-accent-alpha-30: rgba(156, 204, 101, .32);--app-accent-alpha-35: rgba(156, 204, 101, .4);--app-input-bg: #111f33;--app-input-border: #2a4a66;--app-input-text: #f0fdfa;--app-shadow: rgba(0, 0, 0, .35);--app-sidebar-bg: #061222;--app-sidebar-text: #e8f4f0;--app-sidebar-text-muted: #8eb4c9;--app-sidebar-border: #14324a;--app-sidebar-hover: #0f2840;--app-sidebar-active-bg: rgba(156, 204, 101, .2)}[data-theme=light]{color:#0f1f2e;background-color:#e4efe8;color-scheme:light;--app-brand-navy: #0a3d66;--app-page-highlight: rgba(255, 213, 79, .14);--app-bg: #e4efe8;--app-surface: #f8fdfb;--app-border: #dfe6e3;--app-text: #0f1f2e;--app-text-muted: #5c6b73;--app-accent: #6abf4b;--app-accent-hover: #559e3a;--app-accent-light: #9ccc65;--app-accent-deep: #3f6d2c;--app-accent-bg: rgba(106, 191, 75, .14);--app-accent-alpha-10: rgba(106, 191, 75, .1);--app-accent-alpha-15: rgba(106, 191, 75, .15);--app-accent-alpha-20: rgba(106, 191, 75, .2);--app-accent-alpha-30: rgba(106, 191, 75, .3);--app-accent-alpha-35: rgba(106, 191, 75, .35);--app-input-bg: #ffffff;--app-input-border: #d5ddd9;--app-input-text: #0f1f2e;--app-shadow: rgba(10, 61, 102, .12);--app-sidebar-bg: #0a2740;--app-sidebar-text: #f0fdfa;--app-sidebar-text-muted: #9fb8c9;--app-sidebar-border: #143d5c;--app-sidebar-hover: #123351;--app-sidebar-active-bg: rgba(156, 204, 101, .22)}*{box-sizing:border-box}:where(.floating-field-input,input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]):not([type=hidden]):not([type=submit]):not([type=button]):not([type=reset]):not([type=image]),textarea,select){background-color:var(--app-input-bg);color:var(--app-input-text)}[role=dialog] input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]):not([type=hidden]):not([type=submit]):not([type=button]):not([type=reset]):not([type=image]),[role=dialog] textarea,[role=dialog] select,[role=dialog] .floating-field-input,[role=dialog] .floating-field-select-control{background-color:var(--app-input-bg);color:var(--app-input-text);border-color:var(--app-input-border)}body{margin:0;padding:0;min-width:320px;min-height:100vh;font-family:inherit;color:var(--app-text);background-color:var(--app-bg)}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,textarea:-webkit-autofill,textarea:-webkit-autofill:hover,textarea:-webkit-autofill:focus,select:-webkit-autofill,select:-webkit-autofill:hover,select:-webkit-autofill:focus{-webkit-text-fill-color:var(--app-input-text);box-shadow:0 0 0 1000px var(--app-input-bg) inset;caret-color:var(--app-input-text);-webkit-transition:background-color 9999s ease-in-out 0s;transition:background-color 9999s ease-in-out 0s}#root{width:100%;height:100vh;margin:0;padding:0;font-family:inherit;color:var(--app-text);background-color:var(--app-bg)}@media(prefers-color-scheme:dark){:root:not([data-theme]){color:#f0fdfa;background-color:#081420;--app-brand-navy: #8ecae6;--app-page-highlight: rgba(255, 213, 79, .1);--app-bg: #081420;--app-surface: #0f1f33;--app-border: #1e3a52;--app-text: #f0fdfa;--app-text-muted: #94a8b8;--app-accent: #9ccc65;--app-accent-hover: #aed581;--app-accent-light: #c5e1a5;--app-accent-deep: #7cb342;--app-accent-bg: rgba(156, 204, 101, .16);--app-accent-alpha-10: rgba(156, 204, 101, .12);--app-accent-alpha-15: rgba(156, 204, 101, .18);--app-accent-alpha-20: rgba(156, 204, 101, .24);--app-accent-alpha-30: rgba(156, 204, 101, .32);--app-accent-alpha-35: rgba(156, 204, 101, .4);--app-input-bg: #111f33;--app-input-border: #2a4a66;--app-input-text: #f0fdfa;--app-shadow: rgba(0, 0, 0, .35);--app-sidebar-bg: #061222;--app-sidebar-text: #e8f4f0;--app-sidebar-text-muted: #8eb4c9;--app-sidebar-border: #14324a;--app-sidebar-hover: #0f2840;--app-sidebar-active-bg: rgba(156, 204, 101, .2)}}:root[data-proud-american=true]{background-color:transparent;--app-bg: transparent;--app-surface: rgba(255, 255, 255, .78);--app-input-bg: rgba(255, 255, 255, .9);--app-sidebar-bg: rgba(10, 39, 64, .82);--app-border: rgba(223, 230, 227, .75);--app-shadow: rgba(10, 61, 102, .22)}[data-theme=dark][data-proud-american=true]{--app-surface: rgba(17, 31, 51, .82);--app-input-bg: rgba(17, 31, 51, .88);--app-sidebar-bg: rgba(6, 18, 34, .88);--app-border: rgba(42, 74, 102, .65);--app-shadow: rgba(0, 0, 0, .32)}.board-header{background:var(--app-surface);padding:20px 24px;box-shadow:0 1px 3px var(--app-shadow);display:flex;justify-content:space-between;align-items:center;z-index:20;transition:background .2s ease}.board-header-left{display:flex;align-items:flex-start;gap:16px}.board-header-right{display:flex;align-items:center;gap:24px}.board-header-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;margin:0;border:1px solid var(--app-border);border-radius:10px;background:var(--app-surface);color:var(--app-text-muted);cursor:pointer;flex-shrink:0;transition:all .2s ease}.board-header-back:hover{border-color:var(--app-accent);color:var(--app-accent);background:var(--app-accent-bg)}.board-header-title-block{flex:1;min-width:0}.board-header-title{margin:0;font-size:22px;font-weight:700;color:var(--app-text);letter-spacing:-.02em}.board-header-subtitle{margin:6px 0 0;font-size:14px;color:var(--app-text-muted);line-height:1.5}.sidebar{position:fixed;left:0;top:0;height:100vh;width:var(--app-sidebar-expanded-width);font-family:inherit;background-color:var(--app-sidebar-bg);color:var(--app-sidebar-text);display:flex;flex-direction:column;box-shadow:2px 0 8px var(--app-shadow);z-index:1000;transition:width .3s ease,background-color .2s ease;--sidebar-width: var(--app-sidebar-expanded-width)}.sidebar-collapsed{width:80px;--sidebar-width: 80px}.sidebar-header{padding:1.5rem 1.25rem;border-bottom:1px solid var(--app-sidebar-border);transition:padding .3s ease;display:flex;align-items:center;gap:.75rem}.sidebar-header-link{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit;transition:opacity .2s ease;flex:1;min-width:0}.sidebar-header-link:hover{opacity:.8}.sidebar-collapsed .sidebar-header{padding:1rem .5rem;gap:.35rem;justify-content:center}.sidebar-collapsed .sidebar-header-link{flex:0 0 auto;justify-content:center}.sidebar-logo{display:flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;border-radius:8px;overflow:hidden;background:transparent}.sidebar-logo img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.sidebar-collapsed .sidebar-logo{width:32px;height:32px}.sidebar-title{font-size:1.125rem;font-weight:600;margin:0;color:var(--app-sidebar-text);white-space:nowrap;overflow:hidden;transition:opacity .3s ease;letter-spacing:-.02em}.sidebar-title-suffix{font-weight:500;color:var(--app-sidebar-text-muted)}.sidebar-collapsed .sidebar-title{opacity:0;width:0;overflow:hidden}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.sidebar-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.sidebar-menu-bottom{margin-top:auto;padding-top:.5rem;border-top:1px solid var(--app-sidebar-border)}.sidebar-menu-divider{height:1px;background-color:var(--app-sidebar-border);margin:.75rem 0;flex-shrink:0}.sidebar-menu-item{width:100%;padding:.75rem 1rem;background:none;border:none;border-radius:8px;color:var(--app-sidebar-text-muted);cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .2s ease;text-align:left;font-size:.9375rem;font-family:inherit;text-decoration:none}.sidebar-collapsed .sidebar-menu-item{justify-content:center;padding:.75rem}.sidebar-menu-item:hover{background-color:var(--app-sidebar-hover);color:var(--app-sidebar-text)}.sidebar-menu-item.active{background-color:var(--app-accent);color:#fff}.sidebar-menu-item.active:hover{background-color:var(--app-accent-hover)}.sidebar-menu-li-parent .sidebar-menu-item{display:flex;align-items:center;font-weight:600}.sidebar-menu-li-parent .sidebar-menu-label{font-weight:600}.sidebar-menu-expand{margin-left:auto;padding:.25rem;background:none;border:none;color:inherit;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background-color .2s ease}.sidebar-menu-expand:hover{background-color:#ffffff1a}.sidebar-menu-expand svg{transition:transform .2s ease}.sidebar-menu-expand-open svg{transform:rotate(0)}.sidebar-menu-expand:not(.sidebar-menu-expand-open) svg{transform:rotate(-90deg)}.sidebar-menu-li-sub{margin-left:1.75rem;margin-top:-.15rem;padding-left:0;border-left:2px solid var(--app-sidebar-border)}.sidebar-menu-item-sub{padding-left:1.25rem;font-size:.875rem;min-height:2.25rem;border-radius:0}.sidebar-menu-item-sub .sidebar-menu-icon{width:18px;height:18px;opacity:.9}.sidebar-menu-item-sub .sidebar-menu-label{font-weight:500}.sidebar-menu-item-sub:hover{background-color:var(--app-sidebar-hover)}.sidebar-menu-item-sub.active{border-left-color:var(--app-accent);background-color:var(--app-sidebar-active-bg)}.sidebar-menu-item-sub.active:hover{background-color:var(--app-sidebar-active-bg);filter:brightness(1.1)}.sidebar-collapsed .sidebar-menu-li-sub{margin-left:0;border-left:none}.sidebar-collapsed .sidebar-menu-item-sub{padding-left:.75rem}.sidebar-menu-item-logout{width:100%;border:none;background:none;cursor:pointer}.sidebar-menu-item-logout:hover{background-color:var(--app-sidebar-hover);color:var(--app-sidebar-text)}.sidebar-menu-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:24px;height:24px}.sidebar-menu-label{font-weight:500;white-space:nowrap;overflow:hidden;transition:opacity .3s ease}.sidebar-collapsed .sidebar-menu-label{opacity:0;width:0;overflow:hidden}.sidebar-toggle{background:none;border:none;color:var(--app-sidebar-text-muted);cursor:pointer;padding:.5rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.sidebar-toggle:hover{background-color:var(--app-sidebar-hover);color:var(--app-sidebar-text)}.sidebar-toggle:active{transform:scale(.95)}.sidebar-collapsed .sidebar-toggle{padding:.35rem}@media(max-width:768px){.sidebar{width:80px}.sidebar-title,.sidebar-menu-label{display:none}.sidebar-header{justify-content:center;padding:1rem}.sidebar-menu-item{justify-content:center;padding:.75rem}}.database-actions{display:flex;justify-content:flex-end;align-items:center;gap:12px}.database-actions-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#f59e0b;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:0 2px 4px var(--app-shadow)}.database-actions-button:hover:not(:disabled){background-color:#d97706;transform:translateY(-1px);box-shadow:0 4px 6px var(--app-shadow)}.database-actions-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px var(--app-shadow)}.database-actions-button:disabled{opacity:.6;cursor:not-allowed}.database-actions-button-recreate{background-color:#ef4444}.database-actions-button-recreate:hover:not(:disabled){background-color:#dc2626}.database-actions-button svg{flex-shrink:0}.database-actions-spinner{animation:spin 1s linear infinite}[data-theme=dark] .database-actions-button:hover:not(:disabled){background-color:#b45309}[data-theme=dark] .database-actions-button-recreate:hover:not(:disabled){background-color:#b91c1c}.overview-page{width:100%;flex:1;min-height:0;display:flex;flex-direction:column;background:#f1f5f9;overflow:hidden}.overview-page .board-header{flex-shrink:0}.overview-content{flex:1;min-height:0;padding:24px;overflow:hidden;display:flex;flex-direction:column}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;gap:24px;flex:1;min-height:0;width:100%}.overview-card{background:var(--app-surface);border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden;display:flex;flex-direction:column;min-height:0}.overview-card-title{margin:0;padding:18px 20px;font-size:1rem;font-weight:600;color:#1e293b;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:10px;flex-shrink:0}.overview-card-icon{font-size:1.25rem}.overview-list{flex:1;min-height:0;padding:12px 0;overflow-y:auto}.overview-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 20px;border-bottom:1px solid #f1f5f9;transition:background .15s ease}.overview-list-item:last-child{border-bottom:none}.overview-list-item:hover{background:#f8fafc}.overview-list-main{display:flex;flex-direction:column;gap:2px;min-width:0}.overview-list-primary{font-size:.9rem;font-weight:500;color:#334155}.overview-list-meta{font-weight:400;color:#64748b;font-size:.85em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-list-date{font-size:.75rem;color:#64748b}.overview-badge{flex-shrink:0;padding:4px 10px;border-radius:9999px;font-size:.75rem;font-weight:600}.overview-badge--pending{background:#fef3c7;color:#92400e}.overview-badge--accepted{background:#d1fae5;color:#065f46}.overview-badge--rejected{background:#fee2e2;color:#991b1b}.overview-badge--notreceived{background:#fee2e2;color:#dc2626}.overview-badge--passed{background:#d1fae5;color:#065f46}.overview-badge--failed{background:#fee2e2;color:#991b1b}.overview-empty{margin:0;padding:24px 20px;font-size:.875rem;color:#94a3b8;text-align:center}.overview-loading,.overview-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:#64748b;font-size:.9rem}.overview-loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:var(--app-accent);border-radius:50%;animation:overview-spin .8s linear infinite;margin-bottom:16px}.overview-error p{margin:0;color:#dc2626}@keyframes overview-spin{to{transform:rotate(360deg)}}@media(max-width:900px){.overview-grid{grid-template-columns:1fr}}@media(prefers-color-scheme:dark){.overview-page{background:#0f172a}.overview-card{background:#1e293b;box-shadow:0 1px 3px #0000004d}.overview-card-title{color:#f1f5f9;border-bottom-color:#334155}.overview-list-item{border-bottom-color:#334155}.overview-list-item:hover{background:#334155}.overview-list-primary{color:#e2e8f0}.overview-list-date{color:#94a3b8}.overview-empty{color:#64748b}.overview-loading,.overview-error{color:#94a3b8}.overview-loading-spinner{border-color:#334155;border-top-color:var(--app-accent)}.overview-badge--pending{background:#422006;color:#fcd34d}.overview-badge--accepted{background:#064e3b;color:#6ee7b7}.overview-badge--rejected,.overview-badge--notreceived{background:#450a0a;color:#fca5a5}.overview-badge--passed{background:#064e3b;color:#6ee7b7}.overview-badge--failed{background:#450a0a;color:#fca5a5}}.storage-node-card{background:var(--app-surface);border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s ease;border-left:3px solid var(--app-accent);position:relative}.storage-node-card-depth-0{border-left-color:var(--app-accent)}.storage-node-card-depth-1{border-left-color:#10b981}.storage-node-card-depth-2{border-left-color:#f59e0b}.storage-node-card-depth-3{border-left-color:#ef4444}.storage-node-card-depth-4{border-left-color:var(--app-accent-deep)}.storage-node-card-collapsed{padding:12px}.storage-node-card-collapsed .storage-node-card-header{margin-bottom:0;padding-bottom:0}.storage-node-card:hover{box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.storage-node-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:none}.storage-node-card-header-expanded{border-bottom:1px solid #e5e7eb}.storage-node-card-header-right{display:flex;align-items:center;gap:8px}.storage-node-card-toggle{background:var(--app-bg);border:1px solid #e5e7eb;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:600;color:#6b7280;transition:all .2s ease;padding:0;line-height:1}.storage-node-card-toggle:hover{background:#e5e7eb;color:#374151}.storage-node-card-type-expanded{display:flex;justify-content:space-between;font-size:12px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--app-bg)}.storage-node-card-id{margin:0;font-size:14px;font-weight:600;color:#1f2937}.storage-node-card-type{font-size:11px;color:#6b7280;font-weight:400}.storage-node-card-body{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.storage-node-card-children{margin-top:8px;padding-top:8px;border-top:1px solid var(--app-bg)}.storage-node-card-info{display:flex;justify-content:space-between;font-size:12px}.storage-node-card-label{color:#6b7280;font-weight:500}.storage-node-card-value{color:#1f2937;font-weight:400}.storage-node-card-footer{display:flex;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--app-bg)}.storage-node-card-date{font-size:10px;color:#9ca3af}@media(prefers-color-scheme:dark){.storage-node-card{background:#1f2937;border-left-color:var(--app-accent)}.storage-node-card-id{color:var(--app-surface)}.storage-node-card-type,.storage-node-card-label{color:#9ca3af}.storage-node-card-value{color:var(--app-surface)}.storage-node-card-header-expanded{border-bottom-color:#374151}.storage-node-card-footer{border-top-color:#374151}.storage-node-card-date{color:#6b7280}.storage-node-card-toggle{background:#374151;border-color:#4b5563;color:#d1d5db}.storage-node-card-toggle:hover{background:#4b5563;color:var(--app-surface)}.storage-node-card-type-expanded{border-bottom-color:#374151}.storage-node-card-children{border-top-color:#374151}.storage-node-card-depth-0{border-left-color:var(--app-accent)}.storage-node-card-depth-1{border-left-color:#34d399}.storage-node-card-depth-2{border-left-color:#fbbf24}.storage-node-card-depth-3{border-left-color:#f87171}.storage-node-card-depth-4{border-left-color:#a78bfa}}.storage-tree{width:var(--app-sidebar-expanded-width);min-width:250px;background:var(--app-surface);border-right:1px solid #e5e7eb;display:flex;flex-direction:column;height:100%;overflow:hidden}.storage-tree-header{padding:20px 16px;border-bottom:1px solid #e5e7eb;background:var(--app-surface)}.storage-tree-title{margin:0;font-size:18px;font-weight:600;color:#1f2937}.storage-tree-content{flex:1;overflow-y:auto;padding:8px 0}.storage-tree-node{-webkit-user-select:none;-moz-user-select:none;user-select:none}.storage-tree-node-content{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;transition:background-color .15s ease;min-height:32px}.storage-tree-node-content:hover{background-color:var(--app-bg)}.storage-tree-node-has-children{font-weight:500}.storage-tree-node-toggle{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:none;border:none;cursor:pointer;color:#6b7280;transition:color .15s ease;flex-shrink:0}.storage-tree-node-toggle:hover{color:#1f2937}.storage-tree-node-icon-expanded{transform:rotate(90deg)}.storage-tree-node-spacer{width:16px;flex-shrink:0}.storage-tree-node-type{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px;flex-shrink:0;min-width:60px;text-align:center}.storage-tree-node-type-warehouse{background-color:#dbeafe;color:var(--app-accent-deep)}.storage-tree-node-type-zone{background-color:#e0e7ff;color:#3730a3}.storage-tree-node-type-aisle{background-color:#f3e8ff;color:#6b21a8}.storage-tree-node-type-shelf{background-color:#fce7f3;color:#9f1239}.storage-tree-node-type-pallet{background-color:#fef3c7;color:#92400e}.storage-tree-node-type-box{background-color:#d1fae5;color:#065f46}.storage-tree-node-name{font-size:14px;color:#1f2937;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.storage-tree-header-actions{padding:12px 16px;border-bottom:1px solid #e5e7eb;background:var(--app-surface)}.storage-tree-add-root-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background-color:var(--app-accent);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;justify-content:center}.storage-tree-add-root-button:hover,.storage-tree-add-root-button:active{background-color:var(--app-accent-hover)}.storage-tree-node-add{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:var(--app-accent);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .15s ease;flex-shrink:0;opacity:0}.storage-tree-node-content:hover .storage-tree-node-add{opacity:1}.storage-tree-node-add:hover{background-color:var(--app-accent-hover);transform:scale(1.1)}.storage-tree-node-add:active{background-color:var(--app-accent-hover);transform:scale(.95)}.storage-tree-node-children{margin-left:0}.storage-tree-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.storage-tree-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:400px;animation:slideUp .3s ease-out}.storage-tree-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.storage-tree-dialog-title{margin:0;font-size:18px;font-weight:600;color:#1f2937}.storage-tree-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.storage-tree-dialog-close:hover{background-color:var(--app-bg);color:#1f2937}.storage-tree-dialog-content{padding:24px}.storage-tree-dialog-field{margin-bottom:20px}.storage-tree-dialog-field:last-of-type{margin-bottom:24px}.storage-tree-dialog-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.storage-tree-dialog-input,.storage-tree-dialog-select{width:100%;padding:8px 12px;border:1px solid var(--app-input-border);border-radius:6px;font-size:14px;color:var(--app-input-text);background-color:var(--app-input-bg);transition:border-color .15s ease;font-family:inherit}.storage-tree-dialog-input:focus,.storage-tree-dialog-select:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-alpha-10)}.storage-tree-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid #e5e7eb}.storage-tree-dialog-button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.storage-tree-dialog-button-cancel{background-color:var(--app-bg);color:#374151}.storage-tree-dialog-button-cancel:hover{background-color:#e5e7eb}.storage-tree-dialog-button-confirm{background-color:var(--app-accent);color:#fff}.storage-tree-dialog-button-confirm:hover:not(:disabled){background-color:var(--app-accent-hover)}.storage-tree-dialog-button-confirm:disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}@media(prefers-color-scheme:dark){.storage-tree{background:#1f2937;border-right-color:#4b5563}.storage-tree-header{background:#111827;border-bottom-color:#4b5563}.storage-tree-title{color:var(--app-surface)}.storage-tree-node-content:hover{background-color:#374151}.storage-tree-node-toggle{color:#9ca3af}.storage-tree-node-toggle:hover,.storage-tree-node-name{color:var(--app-surface)}.storage-tree-node-type-warehouse{background-color:#1e3a8a;color:var(--app-accent-hover)}.storage-tree-node-type-zone{background-color:#312e81;color:#c7d2fe}.storage-tree-node-type-aisle{background-color:#581c87;color:#e9d5ff}.storage-tree-node-type-shelf{background-color:#831843;color:#fbcfe8}.storage-tree-node-type-pallet{background-color:#78350f;color:#fde68a}.storage-tree-node-type-box{background-color:#064e3b;color:#6ee7b7}.storage-tree-header-actions{background:#111827;border-bottom-color:#4b5563}.storage-tree-add-root-button,.storage-tree-add-root-button:hover{background-color:var(--app-accent-hover)}.storage-tree-node-add{background:var(--app-accent-hover)}.storage-tree-node-add:hover{background-color:var(--app-accent-hover)}.storage-tree-dialog{background:#1f2937}.storage-tree-dialog-header{border-bottom-color:#4b5563}.storage-tree-dialog-title{color:var(--app-surface)}.storage-tree-dialog-close{color:#9ca3af}.storage-tree-dialog-close:hover{background-color:#374151;color:var(--app-surface)}.storage-tree-dialog-label{color:#d1d5db}.storage-tree-dialog-input,.storage-tree-dialog-select{background-color:var(--app-input-bg);border-color:var(--app-input-border);color:var(--app-input-text)}.storage-tree-dialog-input:focus,.storage-tree-dialog-select:focus{border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-alpha-20)}.storage-tree-dialog-footer{border-top-color:#4b5563}.storage-tree-dialog-button-cancel{background-color:#374151;color:#d1d5db}.storage-tree-dialog-button-cancel:hover{background-color:#4b5563}.storage-tree-dialog-button-confirm{background-color:var(--app-accent-hover)}.storage-tree-dialog-button-confirm:hover:not(:disabled){background-color:var(--app-accent-hover)}.storage-tree-dialog-button-confirm:disabled{background-color:#374151;color:#6b7280}}.inventory-board{width:100%;min-height:100vh;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden}.inventory-board-header{background:var(--app-surface);padding:20px 24px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;align-items:center;z-index:20}.inventory-board-header-left{display:flex;align-items:center;gap:16px}.inventory-board-header-right{display:flex;align-items:center;gap:24px}.inventory-board-title{margin:0;font-size:24px;font-weight:700;color:#1f2937}.inventory-board-location{display:flex;align-items:center;gap:8px}.inventory-board-location-label{display:flex;align-items:center;cursor:pointer;color:#6b7280}.inventory-board-location-icon{width:20px;height:20px;color:#6b7280;transition:color .2s ease}.inventory-board-location-label:hover .inventory-board-location-icon{color:var(--app-accent)}.inventory-board-location-select{padding:6px 12px;font-size:14px;color:var(--app-input-text);background-color:var(--app-input-bg);border:1px solid var(--app-input-border);border-radius:6px;cursor:pointer;transition:all .2s ease;min-width:150px}.inventory-board-location-select:hover{border-color:#9ca3af}.inventory-board-location-select:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-alpha-10)}.inventory-board-stats{font-size:14px;color:#6b7280;font-weight:500}.inventory-board-columns{display:flex;padding:24px;overflow-x:auto;overflow-y:hidden;flex:1;gap:8px}.inventory-board-columns::-webkit-scrollbar{height:8px}.inventory-board-columns::-webkit-scrollbar-track{background:transparent}.inventory-board-columns::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.inventory-board-columns::-webkit-scrollbar-thumb:hover{background:#9ca3af}.purchase-group-board-add-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:var(--app-accent);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.purchase-group-board-add-button:hover{background-color:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 2px 4px var(--app-accent-alpha-30)}.purchase-group-board-add-button:active{transform:translateY(0);background-color:var(--app-accent-hover)}@media(prefers-color-scheme:dark){.inventory-board{background:#111827}.inventory-board-header{background:#1f2937}.inventory-board-title{color:var(--app-surface)}.inventory-board-location-label,.inventory-board-location-icon{color:#9ca3af}.inventory-board-location-label:hover .inventory-board-location-icon{color:var(--app-accent)}.inventory-board-location-select{background-color:var(--app-input-bg);border-color:var(--app-input-border);color:var(--app-input-text)}.inventory-board-location-select:hover{border-color:#6b7280}.inventory-board-location-select:focus{border-color:var(--app-accent);box-shadow:0 0 0 3px #60a5fa1a}.inventory-board-stats{color:#9ca3af}.inventory-board-columns::-webkit-scrollbar-thumb{background:#4b5563}.inventory-board-columns::-webkit-scrollbar-thumb:hover{background:#6b7280}.purchase-group-board-add-button,.purchase-group-board-add-button:hover{background-color:var(--app-accent-hover)}.purchase-group-board-add-button:active{background-color:var(--app-accent-deep)}}.purchase-group-summary{padding:16px 20px;background:var(--app-bg);border-top:1px solid var(--app-border)}.purchase-group-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}.purchase-group-summary-block{background:var(--app-surface);border-radius:8px;border:1px solid var(--app-border);padding:14px 16px}.purchase-group-summary-block-full-row{grid-column:1 / -1}@media(max-width:640px){.purchase-group-summary-grid{grid-template-columns:1fr}}.purchase-group-summary-block-title{margin:0 0 10px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--app-text-muted)}.purchase-group-summary-dl{margin:0;display:flex;flex-direction:column;gap:6px}.purchase-group-summary-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.purchase-group-summary-row dt{margin:0;font-size:13px;color:var(--app-text-muted);font-weight:500}.purchase-group-summary-row dd{margin:0;font-size:13px;color:var(--app-text);font-weight:600;text-align:right}.purchase-group-summary-status{text-transform:capitalize}.purchase-group-summary-file-link{background:none;border:none;padding:0;font:inherit;color:var(--app-accent);cursor:pointer;text-decoration:underline}.purchase-group-summary-file-link:hover:not(:disabled){color:var(--app-accent-hover)}.purchase-group-summary-file-link:disabled{cursor:not-allowed;opacity:.7}.purchase-group-summary-file-error{font-size:13px;color:#dc2626}.purchase-group-summary-pass{color:#059669}.purchase-group-summary-fail{color:#dc2626}.purchase-group-summary-empty,.purchase-group-summary-muted{margin:0;font-size:13px;color:var(--app-text-muted)}.purchase-group-card{background:var(--app-surface);border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s ease;border-left:3px solid var(--app-accent)}.purchase-group-card-collapsed{padding:12px}.purchase-group-card-collapsed .purchase-group-card-header{margin-bottom:0;padding-bottom:0}.purchase-group-card:hover{box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.purchase-group-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:none}.purchase-group-card-header-expanded{border-bottom:1px solid #e5e7eb}.purchase-group-card-summary-wrap{margin-top:4px;margin-bottom:8px}.purchase-group-card-header-right{display:flex;align-items:center;gap:8px}.purchase-group-card-toggle{background:var(--app-bg);border:1px solid #e5e7eb;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:600;color:#6b7280;transition:all .2s ease;padding:0;line-height:1}.purchase-group-card-toggle:hover{background:#e5e7eb;color:#374151}.purchase-group-card-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-size:13px;padding:4px 0}.purchase-group-card-status-expanded{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.purchase-group-card-status-badge{font-size:12px;font-weight:600;padding:2px 8px;border-radius:6px;background:#e0e7ff;color:#3730a3}.purchase-group-card-section{margin-bottom:12px}.purchase-group-card-section-title{margin:0 0 6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#6b7280}.purchase-group-card-dl{margin:0;padding:0;list-style:none}.purchase-group-card-dl .purchase-group-card-row{padding:5px 0;border-bottom:1px solid var(--app-bg)}.purchase-group-card-dl .purchase-group-card-row:last-child{border-bottom:none}.purchase-group-card-sub{display:inline-block;margin-left:6px;font-size:12px;color:#6b7280;font-weight:400}.purchase-group-card-mono{font-family:ui-monospace,SF Mono,Monaco,Cascadia Mono,monospace;font-size:12px}.purchase-group-card-name{margin:0;font-size:14px;font-weight:600;color:#1f2937}.purchase-group-card-status{font-size:11px;color:#6b7280;font-weight:400}.purchase-group-card-count{font-size:11px;color:#6b7280;font-weight:500}.purchase-group-card-body{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.purchase-group-card-info{display:flex;justify-content:space-between;font-size:12px}.purchase-group-card-label{color:#6b7280;font-weight:500}.purchase-group-card-value{color:#1f2937;font-weight:400}.purchase-group-card-footer{display:flex;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--app-bg)}.purchase-group-card-date{font-size:10px;color:#9ca3af}.purchase-group-card-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--app-bg)}.purchase-group-card-button{flex:1;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.purchase-group-card-button-accept{background-color:#10b981;color:#fff}.purchase-group-card-button-accept:hover{background-color:#059669;transform:translateY(-1px);box-shadow:0 2px 4px #10b9814d}.purchase-group-card-button-accept:active{transform:translateY(0);background-color:#047857}.purchase-group-card-button-reject{background-color:#ef4444;color:#fff}.purchase-group-card-button-reject:hover{background-color:#dc2626;transform:translateY(-1px);box-shadow:0 2px 4px #ef44444d}.purchase-group-card-button-reject:active{transform:translateY(0);background-color:#b91c1c}.purchase-group-card-button-pending{background-color:var(--app-accent);color:#fff}.purchase-group-card-button-pending:hover{background-color:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 2px 4px var(--app-accent-alpha-30)}.purchase-group-card-button-pending:active{transform:translateY(0);background-color:var(--app-accent-hover)}@media(prefers-color-scheme:dark){.purchase-group-card{background:#1f2937;border-left-color:var(--app-accent)}.purchase-group-card-name{color:var(--app-surface)}.purchase-group-card-status,.purchase-group-card-count,.purchase-group-card-label{color:#9ca3af}.purchase-group-card-value{color:var(--app-surface)}.purchase-group-card-header-expanded{border-bottom-color:#374151}.purchase-group-card-footer{border-top-color:#374151}.purchase-group-card-date{color:#6b7280}.purchase-group-card-toggle{background:#374151;border-color:#4b5563;color:#d1d5db}.purchase-group-card-toggle:hover{background:#4b5563;color:var(--app-surface)}.purchase-group-card-status-expanded{border-bottom-color:#374151}.purchase-group-card-section-title{color:#9ca3af}.purchase-group-card-status-badge{background:#3730a3;color:#e0e7ff}.purchase-group-card-sub{color:#9ca3af}.purchase-group-card-dl .purchase-group-card-row{border-bottom-color:#374151}.purchase-group-card-actions{border-top-color:#374151}.purchase-group-card-button-accept{background-color:#059669}.purchase-group-card-button-accept:hover{background-color:#047857}.purchase-group-card-button-reject{background-color:#dc2626}.purchase-group-card-button-reject:hover{background-color:#b91c1c}.purchase-group-card-button-pending,.purchase-group-card-button-pending:hover{background-color:var(--app-accent-hover)}.purchase-group-card-button-pending:active{background-color:var(--app-accent-deep)}}.new-purchase-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:new-purchase-dialog-fadeIn .2s ease-out}@keyframes new-purchase-dialog-fadeIn{0%{opacity:0}to{opacity:1}}.new-purchase-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;display:flex;flex-direction:column;animation:new-purchase-dialog-slideUp .3s ease-out;overflow:hidden}@keyframes new-purchase-dialog-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.new-purchase-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.new-purchase-dialog-title{margin:0;font-size:20px;font-weight:600;color:#1f2937}.new-purchase-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.new-purchase-dialog-close:hover{background-color:var(--app-bg);color:#1f2937}.new-purchase-dialog-content{padding:24px;display:flex;flex-direction:column;gap:16px}.new-purchase-dialog-label{font-size:14px;font-weight:500;color:#374151}.new-purchase-dialog-file-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.new-purchase-dialog-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.new-purchase-dialog-browse-btn{padding:.5rem 1rem;font-size:14px;font-weight:500;color:#374151;background:var(--app-surface);border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .2s ease}.new-purchase-dialog-browse-btn:hover{background:var(--app-bg);border-color:#9ca3af}.new-purchase-dialog-filename{font-size:14px;color:#6b7280;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-purchase-dialog-error{margin:0;font-size:14px;color:#dc2626}.new-purchase-dialog-preview{background:var(--app-surface);border:1px solid #e5e7eb;border-radius:8px;padding:16px}.new-purchase-dialog-preview-title{margin:0 0 12px;font-size:14px;font-weight:600;color:#1f2937}.new-purchase-dialog-preview-list{margin:0;display:flex;flex-direction:column;gap:8px}.new-purchase-dialog-preview-list div{display:flex;align-items:baseline;gap:8px}.new-purchase-dialog-preview-list dt{margin:0;font-size:13px;color:#6b7280;min-width:64px}.new-purchase-dialog-preview-list dd{margin:0;font-size:14px;font-weight:500;color:#1f2937}.new-purchase-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:8px;margin-top:4px;border-top:1px solid #e5e7eb}.new-purchase-dialog-btn{padding:.5rem 1rem;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;font-family:inherit;border:none}.new-purchase-dialog-btn-cancel{background:var(--app-surface);color:#374151;border:1px solid #d1d5db}.new-purchase-dialog-btn-cancel:hover{background:var(--app-surface);border-color:#9ca3af}.new-purchase-dialog-btn-confirm{background:var(--app-accent);color:#fff}.new-purchase-dialog-btn-confirm:hover:not(:disabled){background:var(--app-accent-hover);box-shadow:0 2px 4px var(--app-accent-alpha-30)}.new-purchase-dialog-btn-confirm:disabled{background:#9ca3af;cursor:not-allowed;opacity:.7}@media(prefers-color-scheme:dark){.new-purchase-dialog{background:#1f2937}.new-purchase-dialog-header{border-bottom-color:#374151}.new-purchase-dialog-title{color:var(--app-surface)}.new-purchase-dialog-close{color:#9ca3af}.new-purchase-dialog-close:hover{background:#374151;color:var(--app-surface)}.new-purchase-dialog-label{color:#e5e7eb}.new-purchase-dialog-browse-btn{background:#374151;color:#e5e7eb;border-color:#4b5563}.new-purchase-dialog-browse-btn:hover{background:#4b5563}.new-purchase-dialog-filename{color:#9ca3af}.new-purchase-dialog-preview{background:#374151;border-color:#4b5563}.new-purchase-dialog-preview-title{color:var(--app-surface)}.new-purchase-dialog-preview-list dt{color:#9ca3af}.new-purchase-dialog-preview-list dd{color:var(--app-surface)}.new-purchase-dialog-footer{border-top-color:#374151}.new-purchase-dialog-btn-cancel{background:#374151;color:#e5e7eb;border-color:#4b5563}.new-purchase-dialog-btn-cancel:hover{background:#4b5563}}.status-column{display:flex;flex-direction:column;min-width:0;flex:1;background:var(--app-bg);border-radius:8px;margin-right:16px;height:100%;max-height:100%}.status-column-header{padding:16px;background:var(--app-surface);border-radius:8px 8px 0 0;border-top:4px solid;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10;box-shadow:0 2px 4px var(--app-shadow)}.status-column-title{margin:0;font-size:16px;font-weight:600;color:var(--app-text)}.status-column-count{background:var(--app-border);color:var(--app-text);padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;min-width:24px;text-align:center}.status-column-content{padding:12px;overflow-y:auto;flex:1;min-height:0}.status-column-empty{display:flex;align-items:center;justify-content:center;padding:40px 20px;color:var(--app-text-muted);font-size:14px;text-align:center}.status-column-empty p{margin:0}.status-column-content::-webkit-scrollbar{width:6px}.status-column-content::-webkit-scrollbar-track{background:transparent}.status-column-content::-webkit-scrollbar-thumb{background:var(--app-border);border-radius:3px}.status-column-content::-webkit-scrollbar-thumb:hover{background:var(--app-text-muted)}.floating-field{position:relative;width:100%}.floating-field-input{width:100%;box-sizing:border-box;min-height:38px;padding:8px 10px;line-height:1.25;border:1px solid var(--app-input-border);border-radius:8px;outline:none;background-color:var(--app-input-bg);color:var(--app-input-text);transition:border-color .15s ease,box-shadow .15s ease}.floating-field-input:focus{border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent-bg)}.floating-field-label{position:absolute;left:12px;top:50%;transform:translateY(-50%);padding:0 4px;font-size:12px;line-height:1;color:var(--app-text-muted);background:transparent;pointer-events:none;opacity:0;z-index:1;transition:top .15s ease,opacity .15s ease,color .15s ease,background-color .15s ease}.floating-field-input:focus::-moz-placeholder{color:transparent}.floating-field-input:focus::placeholder{color:transparent}.floating-field-input:not(:-moz-placeholder)+.floating-field-label{top:0;transform:translateY(-50%);opacity:1;color:var(--app-accent);background:var(--app-input-bg)}.floating-field-input:focus+.floating-field-label,.floating-field-input:not(:placeholder-shown)+.floating-field-label{top:0;transform:translateY(-50%);opacity:1;color:var(--app-accent);background:var(--app-input-bg)}.floating-field-select{position:relative;width:100%}.floating-field-select-label{position:absolute;left:12px;top:0;transform:translateY(-50%);padding:0 4px;font-size:12px;line-height:1;color:var(--app-accent);background:var(--app-input-bg);z-index:1;pointer-events:none}.floating-field-select-control{width:100%;box-sizing:border-box;min-height:38px;padding:10px 10px 5px;border:1px solid var(--app-input-border);border-radius:8px;font-family:inherit;font-size:inherit;line-height:1.25;outline:none;background-color:var(--app-input-bg);color:var(--app-input-text);transition:border-color .15s ease,box-shadow .15s ease}.floating-field-select-control:focus{border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent-bg)}.meter-table-container{width:100%;min-height:100vh;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden}.meter-table-layout{display:flex;flex:1;overflow:hidden;min-height:0}.meter-table-main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.meter-table-actions-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:var(--app-surface);padding:16px 24px;margin-bottom:12px;border-bottom:1px solid var(--app-border);box-shadow:0 1px 3px var(--app-shadow)}.meter-table-search-mode{background:var(--app-surface);padding:12px 24px 0;border-bottom:1px solid var(--app-border)}.meter-table-search-mode-segmented{display:inline-flex;background:var(--app-bg);border-radius:8px;padding:4px;gap:0}.meter-table-search-mode-btn{padding:8px 20px;font-size:.875rem;font-weight:500;color:var(--app-text-muted);background:transparent;border:none;border-radius:6px;cursor:pointer;font-family:inherit;transition:color .2s,background-color .2s;display:inline-flex;align-items:center;gap:6px}.meter-table-search-mode-btn:hover{color:var(--app-text)}.meter-table-search-mode-btn-active{background:var(--app-surface);color:var(--app-text);box-shadow:0 1px 2px var(--app-shadow)}.meter-table-search-mode-badge{color:var(--app-accent);font-weight:700}.meter-table-search-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:var(--app-surface);padding:16px 24px;border-bottom:1px solid var(--app-border);box-shadow:0 1px 3px var(--app-shadow)}.meter-table-filters-panel-advanced{border-top:none}.meter-table-basic-search{flex:0 0 auto;width:600px;max-width:100%;min-width:0}.meter-table-basic-search .meter-search-container,.meter-table-filters-search .meter-search-container{width:100%;max-width:600px}.meter-table-search-left{flex:0 0 auto;width:600px;background:var(--app-surface)}.meter-table-search-right{flex:1;min-width:0;display:flex;align-items:center;justify-content:flex-end}.meter-table-filters-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--app-text);background:var(--app-bg);border:1px solid var(--app-border);border-radius:6px;cursor:pointer;font-family:inherit;transition:background-color .2s,border-color .2s}.meter-table-filters-toggle:hover{background:var(--app-surface);border-color:var(--app-text-muted)}.meter-table-filters-toggle-open{background:var(--app-border);border-color:var(--app-text-muted)}.meter-table-filters-toggle-icon{font-size:.75rem;color:var(--app-text-muted)}.meter-table-filters-badge{color:var(--app-accent);font-weight:700}.meter-table-filters-panel{background:var(--app-bg);padding:14px 20px;border-bottom:1px solid var(--app-border);border-left:3px solid var(--app-border)}.meter-table-filters-search{margin-bottom:14px;width:600px;max-width:100%}.meter-table-filters-row{display:flex;align-items:flex-start;gap:24px}.meter-table-filters-grid{display:grid;grid-template-columns:auto auto auto;gap:0 32px;align-items:start;max-width:720px;flex:0 1 auto}.meter-table-filters-clear{flex-shrink:0;font-size:.75rem;font-weight:500;color:var(--app-accent);background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:4px;font-family:inherit;margin-top:2px}.meter-table-filters-clear:hover:not(:disabled){color:var(--app-accent-hover);background:var(--app-accent-bg)}.meter-table-filters-clear:disabled{color:var(--app-text-muted);cursor:not-allowed}.meter-table-filters-col{display:flex;flex-direction:column;gap:12px;min-width:160px}@media(max-width:640px){.meter-table-filters-grid{grid-template-columns:1fr}.meter-table-filters-col{min-width:0}}.meter-table-filter-field{display:flex;flex-direction:column;gap:4px;min-width:0}.meter-table-filter-label{font-size:.6875rem;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.04em;line-height:1.2}.meter-table-filter-select{padding:5px 8px;font-size:.8125rem;color:var(--app-input-text);background:var(--app-input-bg);border:1px solid var(--app-border);border-radius:4px;cursor:pointer;font-family:inherit;width:100%;max-width:100%;height:28px;line-height:1.2}.meter-table-filter-select:hover{border-color:var(--app-text-muted)}.meter-table-filter-select:focus{border-color:var(--app-accent);outline:none;box-shadow:0 0 0 2px var(--app-accent-bg)}.meter-table-new-purchase-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background-color:var(--app-accent);border:none;border-radius:6px;cursor:pointer;transition:background-color .2s,box-shadow .2s;font-family:inherit}.meter-table-new-purchase-btn:hover{background-color:var(--app-accent-hover);box-shadow:0 2px 4px var(--app-accent-bg)}.meter-table-scan-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--app-text);background-color:var(--app-surface);border:1px solid var(--app-border);border-radius:6px;cursor:pointer;transition:background-color .2s,border-color .2s;font-family:inherit}.meter-table-scan-btn:hover{background-color:var(--app-bg);border-color:var(--app-text-muted)}.meter-table-header{background:var(--app-surface);padding:20px 24px;box-shadow:0 1px 3px var(--app-shadow);display:flex;justify-content:space-between;align-items:center;z-index:20}.meter-table-header-right{display:flex;align-items:center;gap:24px}.meter-table-title{margin:0;font-size:24px;font-weight:700;color:var(--app-text)}.meter-table-count{font-size:14px;color:var(--app-text-muted);font-weight:500}.meter-table-wrapper{flex:1;padding:24px;overflow-x:auto;overflow-y:auto;background:var(--app-surface);margin:0;min-height:0}.meter-table{width:100%;border-collapse:collapse}.meter-table thead{background-color:var(--app-bg);border-bottom:2px solid var(--app-border)}.meter-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.meter-table-th-checkbox,.meter-table-td-checkbox{width:2.75rem;padding:.75rem .5rem .75rem 1rem!important;text-align:center;vertical-align:middle}.meter-table-checkbox-label{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;margin:0}.meter-table-checkbox{width:1rem;height:1rem;cursor:pointer;accent-color:var(--app-accent)}.meter-table tbody tr{border-bottom:1px solid var(--app-border);transition:background-color .15s ease}.meter-table tbody tr:hover{background-color:var(--app-bg)}.meter-table tbody tr:last-child{border-bottom:none}.meter-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--app-text)}.meter-table-code{font-weight:600;color:var(--app-accent)}.meter-table-status{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.meter-table-status-received{background-color:var(--app-accent-bg);color:var(--app-accent-deep)}.meter-table-status-notreceived{background-color:#fee2e2;color:#dc2626}.meter-table-status-intest{background-color:#fef3c7;color:#92400e}.meter-table-status-stocked{background-color:#d1fae5;color:#065f46}.meter-table-status-shipped{background-color:#0a3d661f;color:var(--app-brand-navy)}.meter-table-status-installed{background-color:#6abf4b1f;color:var(--app-accent-deep)}.meter-table-status-testpassed{background-color:#dcfce7;color:#16a34a}.meter-table-status-testfailed{background-color:#fee2e2;color:#dc2626}.meter-table-status-unknown{background-color:var(--app-border);color:var(--app-text-muted)}.meter-table-empty{text-align:center;padding:3rem 1rem!important;color:var(--app-text-muted);font-style:italic}.meter-table-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;background:var(--app-surface);border-bottom:1px solid var(--app-border)}.meter-table-pagination button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--app-text);background:var(--app-surface);border:1px solid var(--app-border);border-radius:6px;cursor:pointer;font-family:inherit}.meter-table-pagination button:hover:not(:disabled){background:var(--app-bg);border-color:var(--app-text-muted)}.meter-table-pagination button:disabled{opacity:.5;cursor:not-allowed}.meter-table-pagination-info{display:inline-flex;align-items:center;gap:.5rem;min-height:1.25rem}.meter-table-pagination-spinner{display:inline-block;width:.875rem;height:.875rem;border:2px solid var(--app-border);border-top-color:var(--app-accent);border-radius:50%;animation:meter-table-pagination-spin .7s linear infinite}@keyframes meter-table-pagination-spin{to{transform:rotate(360deg)}}.meter-table-loading,.meter-table-error{text-align:center;padding:3rem 1rem;color:var(--app-text-muted)}.meter-table-error{color:#dc2626}.meter-table-wrapper{overflow-x:auto}.meter-table{min-width:1200px}.meter-table-actions{white-space:nowrap;padding:.5rem 1rem!important}.meter-table-actions-group{display:inline-flex;align-items:center;gap:.5rem}.meter-table-view-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--app-text-muted);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.meter-table-view-btn:hover{background-color:var(--app-text);transform:translateY(-1px);box-shadow:0 2px 4px var(--app-shadow)}.meter-table-view-btn:active{transform:translateY(0);box-shadow:0 1px 2px var(--app-shadow)}.meter-table-test-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--app-accent);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.meter-table-test-btn:hover:not(:disabled){background-color:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 2px 4px var(--app-accent-bg)}.meter-table-test-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px var(--app-accent-bg)}.meter-table-test-btn:disabled,.meter-table-test-btn-disabled{background-color:var(--app-border);color:var(--app-text-muted);cursor:not-allowed;opacity:.6}.meter-table-test-btn:disabled:hover,.meter-table-test-btn-disabled:hover{transform:none;box-shadow:none}.meter-table-test-icon-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.home-page{width:100%;min-height:100vh;display:flex;flex-direction:column;background:var(--app-bg)}.home-page-body{flex:1;display:flex;min-height:0;width:100%}.home-page-history-sidebar{width:var(--app-sidebar-expanded-width);flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--app-border);background:var(--app-surface);min-height:0}.home-page-history-header{padding:16px 14px 10px;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--app-text-muted)}.home-page-history-empty{padding:8px 14px 12px;font-size:13px;color:var(--app-text-muted)}.home-page-history-list{list-style:none;margin:0;padding:4px 8px 16px;overflow-y:auto;flex:1}.home-page-history-item{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:10px;margin-bottom:2px;border:none;border-radius:8px;background:transparent;color:var(--app-text);font-size:13px;font-family:inherit;cursor:pointer;transition:background-color .15s ease}.home-page-history-item:hover{background:var(--app-input-bg)}.home-page-history-item-active,.home-page-history-item-active:hover{background:var(--app-accent-bg)}.home-page-history-item-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;word-break:break-word}.home-page-history-item-meta{font-size:11px;color:var(--app-text-muted)}.home-page-main-column{flex:1;min-width:0;display:flex;flex-direction:column;overflow:auto}.home-page-content{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.home-page-search-section{margin-bottom:24px}.home-page-search-container{max-width:800px;margin:0 auto}.home-page-search-form{width:100%}.home-page-search-input-wrapper{position:relative;display:flex;align-items:center;background:var(--app-input-bg);border:2px solid var(--app-input-border);border-radius:12px;padding:12px 16px;transition:all .2s ease;box-shadow:0 1px 3px var(--app-shadow)}.home-page-search-input-wrapper:focus-within{border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-bg)}.home-page-search-icon{color:var(--app-text-muted);margin-right:12px;flex-shrink:0}.home-page-search-input{flex:1;border:none;outline:none;font-size:16px;color:var(--app-input-text);background:transparent;font-family:inherit}.home-page-search-input::-moz-placeholder{color:var(--app-text-muted)}.home-page-search-input::placeholder{color:var(--app-text-muted)}.home-page-search-input-wrapper .floating-field-label{display:none}.home-page-search-button{background:var(--app-accent);color:#fff;border:none;border-radius:8px;padding:8px 12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;margin-left:8px}.home-page-search-button:hover,.home-page-search-button:active{background:var(--app-accent-hover)}.home-page-search-results{margin-top:16px;background:var(--app-surface);border-radius:12px;border:1px solid var(--app-border);padding:16px;box-shadow:0 1px 3px var(--app-shadow)}.home-page-search-result{padding:12px;border-bottom:1px solid var(--app-border);color:var(--app-text);font-size:14px;white-space:pre-wrap;word-break:break-word}.home-page-search-result:last-child{border-bottom:none}.home-page-search-loading{color:var(--app-text-muted);font-style:italic}.home-page-search-error{color:#dc2626}.home-page-search-pagination{padding:0 12px 12px;margin:0 -4px 4px;border-bottom:1px solid var(--app-border)}.home-page-search-pagination .meter-table-pagination-info{display:inline-flex;align-items:center;gap:8px}.login-page{--login-navy: #0a3d66;--login-navy-muted: rgba(10, 61, 102, .55);--login-lime: #6abf4b;--login-lime-bright: #9ccc65;--login-lime-hover: #559e3a;--login-yellow-soft: rgba(255, 213, 79, .18);--login-accent: var(--login-lime);--login-accent-bright: var(--login-lime-bright);--login-accent-hover: var(--login-lime-hover);--login-accent-soft: rgba(106, 191, 75, .22);--login-accent-ambient: rgba(10, 61, 102, .11);--login-grid-line: rgba(10, 61, 102, .065);position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;min-height:100vh;background:radial-gradient(ellipse 95% 72% at 50% -12%,var(--login-yellow-soft) 0%,transparent 48%),radial-gradient(ellipse 92% 58% at 50% -8%,rgba(156,204,101,.16) 0%,transparent 52%),radial-gradient(ellipse 58% 48% at 108% 102%,rgba(10,61,102,.09) 0%,transparent 50%),radial-gradient(ellipse 52% 42% at -8% 92%,rgba(10,61,102,.07) 0%,transparent 48%),var(--app-bg);font-family:inherit}[data-theme=dark] .login-page{--login-navy: #8ecae6;--login-navy-muted: rgba(142, 202, 230, .65);--login-lime: #9ccc65;--login-lime-bright: #c5e1a5;--login-lime-hover: #aed581;--login-yellow-soft: rgba(255, 213, 79, .12);--login-accent: #9ccc65;--login-accent-bright: #c5e1a5;--login-accent-hover: #aed581;--login-accent-soft: rgba(156, 204, 101, .22);--login-accent-ambient: rgba(142, 202, 230, .12);--login-grid-line: rgba(156, 204, 101, .07)}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page{--login-navy: #8ecae6;--login-navy-muted: rgba(142, 202, 230, .65);--login-lime: #9ccc65;--login-lime-bright: #c5e1a5;--login-lime-hover: #aed581;--login-yellow-soft: rgba(255, 213, 79, .12);--login-accent: #9ccc65;--login-accent-bright: #c5e1a5;--login-accent-hover: #aed581;--login-accent-soft: rgba(156, 204, 101, .22);--login-accent-ambient: rgba(142, 202, 230, .12);--login-grid-line: rgba(156, 204, 101, .07)}}.login-page-top-actions{position:fixed;top:24px;right:24px;z-index:10}.login-page-recreate-db{padding:10px 16px;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--app-text-muted);background:var(--app-surface);border:1px solid var(--app-border);border-radius:10px;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.login-page-recreate-db:hover:not(:disabled){color:var(--app-text);border-color:var(--login-accent);background:var(--app-bg)}.login-page-recreate-db:disabled{opacity:.7;cursor:not-allowed}.login-page-backdrop{position:absolute;inset:0;pointer-events:none;overflow:hidden}.login-page-backdrop-grid{position:absolute;inset:-1px;background-image:linear-gradient(var(--login-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--login-grid-line) 1px,transparent 1px);background-size:56px 56px;background-position:center top;-webkit-mask-image:radial-gradient(ellipse 85% 65% at 50% -5%,#000 35%,transparent 72%);mask-image:radial-gradient(ellipse 85% 65% at 50% -5%,#000 35%,transparent 72%)}.login-page-backdrop-glow{position:absolute;inset:0;background:radial-gradient(ellipse 90% 55% at 50% -10%,var(--login-accent-soft) 0%,transparent 55%),radial-gradient(ellipse 50% 45% at 100% 100%,var(--login-accent-ambient) 0%,transparent 55%),radial-gradient(ellipse 40% 35% at 0% 85%,var(--login-accent-ambient) 0%,transparent 50%)}.login-page-card{position:relative;width:100%;max-width:420px;background:var(--app-surface);border:1px solid color-mix(in srgb,var(--app-border) 78%,var(--login-navy) 22%);border-radius:18px;box-shadow:0 25px 50px -12px var(--app-shadow),0 0 0 1px color-mix(in srgb,var(--app-border) 92%,transparent),0 0 48px -20px var(--login-accent-soft)}.login-page-card-inner{padding:40px 32px}.login-page-header{text-align:center;margin-bottom:32px}.login-page-brand{display:flex;flex-direction:column;align-items:center;gap:12px}.login-page-brand-img{display:block;width:auto;max-width:160px;max-height:160px;height:auto;-o-object-fit:contain;object-fit:contain}.login-page-title{margin:0;font-size:1.375rem;font-weight:700;color:var(--app-text);letter-spacing:-.03em;line-height:1.2}.login-page-title-suffix{font-weight:600;color:var(--app-text-muted);letter-spacing:-.02em}.login-page-subtitle{margin:0;font-size:.9375rem;font-weight:500;color:color-mix(in srgb,var(--login-navy) 22%,var(--app-text-muted));letter-spacing:-.01em}[data-theme=dark] .login-page-subtitle{color:color-mix(in srgb,var(--login-lime-bright) 12%,var(--app-text-muted))}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page-subtitle{color:color-mix(in srgb,var(--login-lime-bright) 12%,var(--app-text-muted))}}.login-page-form{display:flex;flex-direction:column;gap:20px}.login-page-forgot-wrap{text-align:right;margin-top:-8px}.login-page-2fa-email{margin:0 0 4px;font-size:.875rem;color:var(--app-text-muted);line-height:1.4;text-align:center;word-break:break-all}.login-page-2fa-resend{text-align:center;margin-top:4px}.login-page-text-link{color:var(--login-navy);text-decoration:none;font-size:.875rem;font-weight:600;font-family:inherit;background:none;border:none;padding:0;cursor:pointer;transition:color .2s}.login-page-text-link:hover{text-decoration:underline;color:var(--login-lime-hover)}[data-theme=dark] .login-page-text-link{color:var(--login-lime-bright)}[data-theme=dark] .login-page-text-link:hover{color:#dcecc0}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page-text-link{color:var(--login-lime-bright)}:root:not([data-theme]) .login-page-text-link:hover{color:#dcecc0}}.login-page-back-wrap{margin-bottom:8px;text-align:left}.login-page-success{padding:12px 14px;background:var(--login-accent-soft);border:1px solid color-mix(in srgb,var(--login-accent) 28%,var(--app-border) 72%);border-radius:10px;font-size:.875rem;color:var(--app-text);line-height:1.45}.login-page-error{padding:12px 14px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:10px;font-size:.875rem;color:#fca5a5}.login-page-field{display:flex;flex-direction:column;gap:8px}.login-page-label{font-size:.875rem;font-weight:500;color:var(--app-text-muted)}.login-page-input{width:100%;padding:12px 14px;font-size:1rem;font-family:inherit;color:var(--app-input-text);background:var(--app-input-bg);border:1px solid var(--app-input-border);border-radius:10px;outline:none;transition:border-color .2s,box-shadow .2s}.login-page-input::-moz-placeholder{color:var(--app-text-muted)}.login-page-input::placeholder{color:var(--app-text-muted)}.login-page-input:hover:not(:disabled){border-color:color-mix(in srgb,var(--app-input-border) 62%,var(--login-navy) 38%)}.login-page-input:focus{border-color:var(--login-lime);box-shadow:0 0 0 3px var(--login-accent-soft)}.login-page-input:disabled{opacity:.7;cursor:not-allowed}.login-page .floating-field-input:not(:-moz-placeholder)+.floating-field-label{color:var(--login-navy)}.login-page .floating-field-input:focus+.floating-field-label,.login-page .floating-field-input:not(:placeholder-shown)+.floating-field-label{color:var(--login-navy)}[data-theme=dark] .login-page .floating-field-input:not(:-moz-placeholder)+.floating-field-label{color:var(--login-lime)}[data-theme=dark] .login-page .floating-field-input:focus+.floating-field-label,[data-theme=dark] .login-page .floating-field-input:not(:placeholder-shown)+.floating-field-label{color:var(--login-lime)}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page .floating-field-input:not(:-moz-placeholder)+.floating-field-label{color:var(--login-lime)}:root:not([data-theme]) .login-page .floating-field-input:focus+.floating-field-label,:root:not([data-theme]) .login-page .floating-field-input:not(:placeholder-shown)+.floating-field-label{color:var(--login-lime)}}.login-page-submit{margin-top:8px;padding:14px 20px;font-size:1rem;font-weight:600;font-family:inherit;color:#052032;background:linear-gradient(168deg,var(--login-lime-bright) 0%,var(--login-lime) 42%,var(--login-lime-hover) 100%);border:none;border-radius:12px;cursor:pointer;box-shadow:0 10px 26px -10px #0a3d666b,0 0 0 1px #0a3d6614;transition:opacity .2s,transform .1s,box-shadow .2s}[data-theme=dark] .login-page-submit{color:#061f2e;box-shadow:0 12px 28px -10px #00000080,0 0 32px -10px #9ccc6559}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page-submit{color:#061f2e;box-shadow:0 12px 28px -10px #00000080,0 0 32px -10px #9ccc6559}}.login-page-submit:hover:not(:disabled){opacity:.98;box-shadow:0 14px 32px -10px #0a3d6661,0 0 0 1px #0a3d660f}[data-theme=dark] .login-page-submit:hover:not(:disabled){box-shadow:0 16px 36px -10px #00000073,0 0 40px -8px #9ccc6566}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page-submit:hover:not(:disabled){box-shadow:0 16px 36px -10px #00000073,0 0 40px -8px #9ccc6566}}.login-page-submit:active:not(:disabled){transform:scale(.99)}.login-page-submit:disabled{opacity:.7;cursor:not-allowed}.login-page-footer{margin:24px 0 0;text-align:center;font-size:.8125rem;color:var(--app-text-muted);line-height:1.45}.login-page-link{color:var(--login-navy);text-decoration:none;font-weight:600}.login-page-link:hover{text-decoration:underline;color:var(--login-lime-hover)}[data-theme=dark] .login-page-link{color:var(--login-lime-bright)}[data-theme=dark] .login-page-link:hover{color:#dcecc0}@media(prefers-color-scheme:dark){:root:not([data-theme]) .login-page-link{color:var(--login-lime-bright)}:root:not([data-theme]) .login-page-link:hover{color:#dcecc0}}.signup-page{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;align-items:safe center;padding:24px;min-height:100vh;box-sizing:border-box;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;font-family:inherit;color:var(--app-text);background:var(--app-bg)}.signup-page-backdrop{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,var(--app-accent-bg) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(10,61,102,.08) 0%,transparent 50%);pointer-events:none}.signup-page-card{position:relative;flex-shrink:0;width:100%;max-width:440px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:16px;box-shadow:0 25px 50px -12px var(--app-shadow),0 0 0 1px var(--app-border)}.signup-page-card-inner{padding:40px 32px}.signup-page-header{text-align:center;margin-bottom:28px}.signup-page-brand{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:16px}.signup-page-brand-img{display:block;width:auto;max-width:160px;max-height:160px;height:auto;-o-object-fit:contain;object-fit:contain}.signup-page-brand-lockup{margin:0;font-size:1.125rem;font-weight:700;color:var(--app-text);letter-spacing:-.03em;line-height:1.2}.signup-page-brand-suffix{font-weight:600;color:var(--app-text-muted);letter-spacing:-.02em}.signup-page-brand--compact{margin-bottom:20px}.signup-page-brand--compact .signup-page-brand-img{max-width:96px;max-height:96px}.signup-page-title{margin:0 0 4px;font-size:1.5rem;font-weight:700;color:var(--app-text);letter-spacing:-.02em}.signup-page-subtitle{margin:0;font-size:.9375rem;color:var(--app-text-muted)}.signup-page-step-hint{margin:8px 0 0;font-size:.875rem;color:var(--app-text-muted);line-height:1.4}.signup-page-info{margin:0;padding:12px 14px;background:var(--app-accent-bg);border:1px solid var(--app-border);border-radius:10px;font-size:.875rem;color:var(--app-text-muted);line-height:1.45}.signup-page-resend-ok{padding:12px 14px;background:var(--app-accent-bg);border:1px solid color-mix(in srgb,var(--app-accent) 30%,var(--app-border) 70%);border-radius:10px;font-size:.875rem;color:var(--app-text);line-height:1.45}.signup-page-back-row{margin-bottom:4px;text-align:left}.signup-page-2fa-email{margin:0 0 4px;font-size:.875rem;color:var(--app-text-muted);line-height:1.4;text-align:center;word-break:break-all}.signup-page-2fa-resend{text-align:center;margin-top:4px}.signup-page-text-link{color:var(--app-accent);text-decoration:none;font-size:.875rem;font-weight:600;font-family:inherit;background:none;border:none;padding:0;cursor:pointer;transition:color .2s}.signup-page-text-link:hover:not(:disabled){text-decoration:underline;color:var(--app-text)}.signup-page-text-link:disabled{opacity:.6;cursor:not-allowed}.signup-page-form{display:flex;flex-direction:column;gap:18px}.signup-page-error{padding:12px 14px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:10px;font-size:.875rem;color:#fca5a5}.signup-page-field{display:flex;flex-direction:column;gap:8px}.signup-page-label{font-size:.875rem;font-weight:500;color:var(--app-text-muted)}.signup-page-input{width:100%;padding:12px 14px;font-size:1rem;font-family:inherit;color:var(--app-input-text);background:var(--app-input-bg);border:1px solid var(--app-input-border);border-radius:10px;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.signup-page-input::-moz-placeholder{color:var(--app-text-muted)}.signup-page-input::placeholder{color:var(--app-text-muted)}.signup-page-input:hover:not(:disabled){border-color:var(--app-text-muted)}.signup-page-input:focus{border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-bg)}.signup-page-input:disabled{opacity:.7;cursor:not-allowed}.signup-page-textarea{resize:vertical;min-height:80px}.signup-page-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.signup-page-back{margin-bottom:8px;padding:0;font-size:.875rem;font-family:inherit;color:var(--app-text-muted);background:none;border:none;cursor:pointer;text-align:left;transition:color .2s}.signup-page-back:hover{color:var(--app-accent)}.signup-page-submit{margin-top:6px;padding:14px 20px;font-size:1rem;font-weight:600;font-family:inherit;color:#fff;background:linear-gradient(135deg,var(--app-accent) 0%,var(--app-accent-hover) 100%);border:none;border-radius:10px;cursor:pointer;transition:opacity .2s,transform .1s}.signup-page-submit:hover:not(:disabled){opacity:.95}.signup-page-submit:active:not(:disabled){transform:scale(.99)}.signup-page-submit:disabled{opacity:.7;cursor:not-allowed}.signup-page-footer{margin:24px 0 0;text-align:center;font-size:.8125rem;color:var(--app-text-muted)}.signup-page-link{color:var(--app-accent);text-decoration:none;font-weight:500}.signup-page-link:hover{text-decoration:underline}.signup-page-success{text-align:center;padding:16px 0}.signup-page-success-icon{width:56px;height:56px;margin:0 auto 20px;color:#22c55e;display:block}.signup-page-success-title{margin:0 0 8px;font-size:1.25rem;font-weight:700;color:var(--app-text)}.signup-page-success-text{margin:0;font-size:.9375rem;color:var(--app-text-muted);line-height:1.5}.signup-page-dev-quick{margin-bottom:1.25rem;padding:1rem 1.125rem;border-radius:10px;border:1px dashed rgba(234,179,8,.55);background:#eab30812}.signup-page-dev-quick-title{margin:0 0 .35rem;font-size:.8125rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#a16207}.signup-page-dev-quick-hint{margin:0 0 1rem;font-size:.8125rem;line-height:1.45;color:var(--app-text-muted)}.signup-page-dev-quick-form{display:flex;flex-direction:column;gap:.75rem}.signup-page-dev-quick-submit{margin-top:.25rem}.admin-users-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.admin-users-content{flex:1;padding:24px;width:100%;max-width:none;margin:0 auto;display:flex;gap:16px;align-items:flex-start}.admin-users-tabs{width:220px;display:flex;flex-direction:column;gap:8px;position:sticky;top:24px}.admin-users-tab-btn{width:100%;text-align:left;padding:10px 14px;border-radius:8px;border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text);cursor:pointer;transition:border-color .15s ease,background .15s ease}.admin-users-tab-btn:hover{border-color:var(--app-accent);background:var(--app-accent-bg)}.admin-users-tab-btn--active{border-color:var(--app-accent);background:var(--app-accent-bg);color:var(--app-accent)}.admin-users-section{flex:1;margin:0;padding:24px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:8px}.admin-users-account-section{margin-bottom:24px}.admin-users-label{display:block;font-weight:600;color:var(--app-text);margin-bottom:8px;font-size:.9375rem}.admin-users-account-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.admin-users-input{flex:1;min-width:200px;padding:10px 12px;border:1px solid var(--app-border);border-radius:8px;font-size:.9375rem;color:var(--app-input-text);background:var(--app-input-bg)}.admin-users-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent-bg)}.admin-users-btn{padding:10px 18px;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;border:none;transition:background-color .2s ease}.admin-users-btn:disabled{opacity:.6;cursor:not-allowed}.admin-users-btn-primary{background:var(--app-accent);color:#fff}.admin-users-btn-primary:hover:not(:disabled){background:var(--app-accent-hover)}.admin-users-btn-ghost{background:var(--app-surface);border:1px solid var(--app-border);color:var(--app-text)}.admin-users-btn-danger{background:transparent;border:1px solid #d04646;color:#d04646}.admin-users-row-actions{display:flex;gap:8px}.admin-users-error{margin:8px 0 0;color:#dc2626;font-size:.875rem}.admin-users-error-block{margin:0 0 24px;padding:12px 16px;background:#ef44441a;border-radius:8px;border:1px solid rgba(239,68,68,.3);color:#dc2626}.admin-users-toolbar{margin-bottom:16px}.admin-users-list-section{margin-bottom:32px}.admin-users-section-title{font-size:1.125rem;font-weight:600;color:var(--app-text);margin:0 0 16px}.admin-users-user-lists{display:flex;flex-direction:column;gap:28px}.admin-users-subsection{margin:0}.admin-users-subsection-title{font-size:1.0625rem;font-weight:600;color:var(--app-text);margin:0 0 6px}.admin-users-subsection-hint{margin:0 0 12px;font-size:.8125rem;color:var(--app-text-muted)}.admin-users-empty-inline{margin:0;padding:16px 20px}.admin-users-empty{color:var(--app-text-muted);font-size:.9375rem;padding:24px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:8px}.admin-users-table-wrap{overflow-x:auto;background:var(--app-surface);border:1px solid var(--app-border);border-radius:8px}.admin-users-table{width:100%;border-collapse:collapse;font-size:.9375rem}.admin-users-table th,.admin-users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--app-border);color:var(--app-text)}.admin-users-table th{font-weight:600;color:var(--app-text-muted);background:var(--app-bg)}.admin-users-table tbody tr:last-child td{border-bottom:none}.admin-users-table tbody tr:hover{background:var(--app-bg)}.admin-users-dialog--invite.admin-users-dialog--role{max-width:min(1120px,calc(100vw - 40px));width:100%}.admin-users-permissions-grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:12px}.admin-users-permissions-group{border:1px solid var(--app-border);border-radius:10px;padding:12px 14px;background:var(--app-bg)}.admin-users-permissions-group-title{margin:0 0 10px;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--app-text-muted)}.admin-users-permission-row{display:grid;grid-template-columns:1fr auto auto;gap:10px 14px;align-items:center;padding:6px 0;border-bottom:1px solid color-mix(in srgb,var(--app-border) 80%,transparent)}.admin-users-permissions-group .admin-users-permission-row:last-child{border-bottom:none;padding-bottom:0}.admin-users-permission-name{font-size:.875rem;font-weight:500;color:var(--app-text);text-transform:capitalize}.admin-users-permission-toggle{display:inline-flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--app-text-muted);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin:0;white-space:nowrap}.admin-users-permission-toggle input{width:16px;height:16px;margin:0;accent-color:var(--app-accent);cursor:pointer;flex-shrink:0}.admin-users-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:admin-users-fadeIn .2s ease-out}@keyframes admin-users-fadeIn{0%{opacity:0}to{opacity:1}}.admin-users-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px var(--app-shadow, rgba(0, 0, 0, .1)),0 10px 10px -5px var(--app-shadow, rgba(0, 0, 0, .04));max-width:480px;width:100%;animation:admin-users-slideUp .3s ease-out;overflow:hidden}@keyframes admin-users-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.admin-users-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border)}.admin-users-dialog-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--app-text)}.admin-users-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--app-text-muted);display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.admin-users-dialog-close:hover{background-color:var(--app-bg);color:var(--app-text)}.admin-users-dialog-form{padding:24px;background:var(--app-surface)}.admin-users-dialog--invite{max-width:520px;border-radius:12px;border:1px solid var(--app-border);box-shadow:0 0 0 1px color-mix(in srgb,var(--app-text) 4%,transparent),0 24px 48px -12px var(--app-shadow, rgba(0, 0, 0, .18))}.admin-users-dialog-header--rich{align-items:flex-start;gap:8px 16px;padding:20px 22px 18px;background:color-mix(in srgb,var(--app-accent) 6%,var(--app-surface));border-bottom:1px solid var(--app-border)}.admin-users-dialog-lead{display:flex;align-items:flex-start;gap:14px;min-width:0;flex:1;padding-top:2px}.admin-users-dialog-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--app-accent-bg);color:var(--app-accent);border:1px solid color-mix(in srgb,var(--app-accent) 22%,transparent)}.admin-users-dialog-lead-text{min-width:0}.admin-users-dialog-subtitle{margin:4px 0 0;max-width:32rem;font-size:.875rem;line-height:1.45;color:var(--app-text-muted);font-weight:400}.admin-users-dialog-form--invite{display:flex;flex-direction:column;gap:0;padding:20px 24px 24px}.admin-users-form-section{margin:0 0 22px}.admin-users-form-section:last-of-type{margin-bottom:0}.admin-users-form-section-label{margin:0 0 10px;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--app-text-muted)}.admin-users-form-two-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px;margin-bottom:12px}.admin-users-form-full{margin:0}@media(max-width:480px){.admin-users-form-two-cols{grid-template-columns:1fr}}.admin-users-floating{width:100%;min-width:0}.admin-users-floating .floating-field,.admin-users-floating.floating-field-select,.admin-users-floating-select-wrap.floating-field-select{width:100%}.admin-users-floating-input{min-height:38px;padding:8px 12px;font-size:.9375rem;border:1px solid var(--app-input-border);border-radius:8px;color:var(--app-input-text);background:var(--app-input-bg);transition:border-color .15s ease,box-shadow .15s ease}.admin-users-floating-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent-bg)}.admin-users-floating-select-wrap .floating-field-select-control.admin-users-floating-input{height:auto;min-height:38px;padding:10px 12px 5px;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.admin-users-form-hint{margin:8px 0 0;font-size:.75rem;line-height:1.4;color:var(--app-text-muted)}.admin-users-form-hint--below-label{margin:4px 0 14px}.admin-users-error-box{margin:16px 0 0;padding:10px 12px;border-radius:8px;border:1px solid rgba(239,68,68,.35);background:#ef444414;font-size:.875rem}.admin-users-dialog-form--invite .admin-users-dialog-footer{margin-top:8px;padding-top:20px}.admin-users-dialog-form .admin-users-form-grid{margin-bottom:16px}.admin-users-dialog-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--app-border)}.admin-users-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:20px}.admin-users-field{display:flex;flex-direction:column;gap:6px}.admin-users-field label{font-size:.875rem;font-weight:500;color:var(--app-text)}@media(max-width:860px){.admin-users-content{flex-direction:column}.admin-users-tabs{width:100%;position:static;flex-direction:row;flex-wrap:wrap}}@media(max-width:900px){.admin-users-permissions-grid{grid-template-columns:1fr}}.my-profile-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.my-profile-content{flex:1;padding:24px;max-width:560px;width:100%;margin:0 auto}.my-profile-empty{color:var(--app-text-muted);font-size:.9375rem}.my-profile-dl{margin:0;padding:24px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:8px;display:grid;grid-template-columns:auto 1fr;gap:.75rem 2rem}.my-profile-dl dt{font-weight:600;color:var(--app-text-muted);font-size:.875rem}.my-profile-dl dd{margin:0;color:var(--app-text);font-size:.9375rem}.my-profile-monospace{font-family:ui-monospace,monospace;font-size:.875rem;word-break:break-all}.ship-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden}.ship-page-content{flex:1;padding:24px;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:20px}.ship-page-content p{margin:0;color:var(--app-text-muted);font-size:1rem}.ship-page-error{color:#dc2626;font-size:14px}.ship-page-muted{color:var(--app-text-muted);font-size:14px}.ship-page-actions{flex-shrink:0}.ship-page-create-button{padding:12px 24px;font-size:15px;font-weight:600;font-family:inherit;color:#fff;background:#16a34a;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease}.ship-page-create-button:hover:not(:disabled){background:#15803d}.ship-page-create-button:disabled{opacity:.7;cursor:not-allowed}.ship-page-list-section{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--app-surface);border:1px solid var(--app-border);border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px var(--app-shadow)}.ship-page-list-title{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--app-text)}.ship-page-empty{color:var(--app-text-muted);font-size:14px;margin:0}.ship-page-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.ship-page-item{display:flex;align-items:center;gap:10px;transition:background .2s ease}.ship-page-item-link{display:flex;flex:1;min-width:0;padding:14px 16px;background:var(--app-bg);border:1px solid var(--app-border);border-radius:8px;text-decoration:none;color:inherit;transition:background .2s ease}.ship-page-item-link:hover{background:var(--app-surface)}.ship-page-item-main{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.ship-page-item-id{font-size:14px;font-weight:600;color:var(--app-text);font-family:ui-monospace,monospace}.ship-page-item-meta{font-size:13px;color:var(--app-text-muted)}.ship-page-item-date{font-size:12px;color:var(--app-text-muted)}.ship-page-item-delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--app-text-muted);background:transparent;border:1px solid var(--app-border);border-radius:8px;cursor:pointer;font-size:18px;line-height:1;transition:color .2s ease,background .2s ease,border-color .2s ease}.ship-page-item-delete:hover:not(:disabled){color:#dc2626;background:#ef44441a;border-color:#ef44444d}.ship-page-item-delete:disabled{opacity:.7;cursor:not-allowed}.ship-page-item-delete-spinner{animation:ship-page-item-delete-spin .8s linear infinite}@keyframes ship-page-item-delete-spin{to{transform:rotate(360deg)}}.ship-session-page.add-new-devices-page{height:100vh;overflow:hidden}.ship-session-page .add-new-devices-content{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;max-width:none;width:100%;margin:0;padding-left:24px;padding-right:24px}.ship-session-layout{flex:1;min-height:0}.ship-session-containers-column{overflow-y:auto}.ship-session-containers-desc{margin:0 0 12px;font-size:13px;color:var(--app-text-muted)}.ship-session-muted{margin:0;color:var(--app-text-muted);font-size:14px}.ship-session-empty{margin:0;font-size:13px;color:var(--app-text-muted)}.ship-session-containers-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.ship-session-container-item{display:flex;align-items:stretch}.ship-session-container-item-main{position:relative;display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;flex:1;min-width:0;padding:12px 42px 12px 14px;background:var(--app-bg);border:1px solid var(--app-border);border-radius:8px;transition:background .2s ease}.ship-session-container-item-main:hover{background:var(--app-surface)}.ship-session-container-type{flex-shrink:0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--app-text-muted);padding:2px 6px;background:var(--app-border);border-radius:4px}.ship-session-container-label{flex:1;min-width:0;font-size:14px;font-weight:500;color:var(--app-text);font-family:ui-monospace,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ship-session-container-meta{font-size:12px;color:var(--app-text-muted);flex:1 1 100%;min-width:0}.ship-session-container-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;font-size:18px;line-height:1;color:var(--app-text-muted);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:color .2s ease,background .2s ease}.ship-session-container-remove:hover:not(:disabled){color:#dc2626;background:#ef44441a}.ship-session-container-remove:disabled{opacity:.7;cursor:not-allowed}.ship-session-scan-area{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;padding-top:48px}.ship-session-main-fill{flex:1;min-height:0}.ship-session-confirm-wrap{flex-shrink:0;margin-top:24px;padding-top:24px;padding-right:24px;display:flex;justify-content:flex-end}.pack-config-panel{max-width:480px}.pack-config-form{display:flex;flex-direction:column;gap:20px}.pack-config-field{display:flex;flex-direction:column;gap:8px}.pack-config-field label{font-size:14px;font-weight:600;color:var(--app-text)}.pack-config-input{width:100%;max-width:200px;padding:10px 14px;font-size:15px;font-family:inherit;border:1px solid var(--app-border);border-radius:8px;background:var(--app-input-bg);color:var(--app-input-text);transition:border-color .2s ease,box-shadow .2s ease}.pack-config-input:hover:not(:disabled){border-color:var(--app-text-muted)}.pack-config-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-bg)}.pack-config-input::-webkit-outer-spin-button,.pack-config-input::-webkit-inner-spin-button{opacity:1}.pack-config-start-button{align-self:flex-start;padding:12px 24px;font-size:15px;font-weight:600;font-family:inherit;color:#fff;background:var(--app-accent);border:none;border-radius:8px;cursor:pointer;transition:background .2s ease,transform .1s ease;margin-top:8px}.pack-config-start-button:hover{background:var(--app-accent-hover)}.pack-config-start-button:active{transform:scale(.98)}.add-new-devices-page:has(.pack-page-content){height:100vh;overflow:hidden}.add-new-devices-page:has(.pack-page-content) .add-new-devices-content{max-width:none;width:100%;margin:0;padding-left:24px;padding-right:24px}.pack-page-content{display:flex;flex-direction:column;gap:24px;width:100%;max-width:none;flex:1;min-height:0;overflow:hidden}.pack-page-header{flex-shrink:0;background:var(--app-surface);border:1px solid var(--app-border);border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px var(--app-shadow)}.pack-config-inline,.pack-config-inline-fields{display:flex;flex-wrap:wrap;align-items:flex-end;gap:20px}.pack-config-inline-fields-landing{margin-bottom:20px}.pack-config-inline .pack-config-field{margin:0}.pack-config-inline .pack-config-start-button{margin-top:0}.pack-config-start-wrap{margin-left:auto}.pack-config-error{margin:12px 0 0;font-size:14px;color:#dc2626}.pack-sessions-muted{margin:0;font-size:14px;color:var(--app-text-muted)}.pack-session-delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--app-text-muted);background:transparent;border:1px solid var(--app-border);border-radius:8px;cursor:pointer;transition:color .2s ease,background .2s ease,border-color .2s ease}.pack-session-delete:hover:not(:disabled){color:#dc2626;background:#ef44441a;border-color:#ef44444d}.pack-session-delete:disabled{opacity:.7;cursor:not-allowed}.pack-session-delete-spinner{animation:pack-session-delete-spin .8s linear infinite}@keyframes pack-session-delete-spin{to{transform:rotate(360deg)}}.pack-session-bar{display:flex;align-items:center;gap:16px;margin-bottom:16px}.pack-session-id{font-size:14px;color:var(--app-text-muted);font-family:ui-monospace,monospace}.pack-complete-storage-button{margin-left:auto;padding:8px 16px;font-size:14px;font-weight:600;font-family:inherit;color:#fff;background:#16a34a;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease}.pack-complete-storage-button:hover{background:#15803d}.pack-complete-storage-wrap{flex-shrink:0;margin-top:24px;padding-top:24px;display:flex;justify-content:flex-end}.pack-complete-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.pack-complete-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px var(--app-shadow),0 10px 10px -5px var(--app-shadow);max-width:420px;width:100%;display:flex;flex-direction:column;overflow:hidden}.pack-complete-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border)}.pack-complete-dialog-title{margin:0;font-size:18px;font-weight:600;color:var(--app-text)}.pack-complete-dialog-close{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:20px;line-height:1;color:var(--app-text-muted);border-radius:6px;transition:background .2s ease,color .2s ease}.pack-complete-dialog-close:hover:not(:disabled){background:var(--app-bg);color:var(--app-text)}.pack-complete-dialog-close:disabled{cursor:not-allowed;opacity:.6}.pack-complete-dialog-content{padding:24px;display:flex;flex-direction:column;gap:16px}.pack-complete-dialog-summary{margin:0;font-size:14px;color:var(--app-text-muted);line-height:1.5}.pack-complete-dialog-list{margin:0;padding-left:20px;font-size:14px;color:var(--app-text)}.pack-complete-dialog-list li{margin-bottom:4px}.pack-complete-dialog-boxes{margin-top:4px}.pack-complete-dialog-boxes-label{font-size:13px;font-weight:600;color:var(--app-text-muted);display:block;margin-bottom:8px}.pack-complete-dialog-boxes-list{margin:0;padding-left:20px;font-size:13px;color:var(--app-text-muted)}.pack-complete-dialog-boxes-list li{margin-bottom:2px}.pack-complete-dialog-destination{margin-top:16px;padding-top:16px;border-top:1px solid var(--app-border)}.pack-complete-dialog-destination-label{display:block;font-size:14px;font-weight:600;color:var(--app-text);margin-bottom:10px}.pack-complete-dialog-destination-options{display:flex;gap:20px;flex-wrap:wrap}.pack-complete-dialog-destination-option{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--app-text)}.pack-complete-dialog-destination-option input{margin:0;cursor:pointer}.pack-complete-dialog-place{margin-top:12px}.pack-complete-dialog-place-label{display:block;font-size:14px;font-weight:600;color:var(--app-text);margin-bottom:8px}.pack-complete-dialog-place-select{width:100%;max-width:320px;padding:10px 12px;font-size:14px;font-family:inherit;border:1px solid var(--app-border);border-radius:8px;background:var(--app-input-bg);color:var(--app-input-text)}.pack-complete-dialog-place-select:disabled{background-color:color-mix(in srgb,var(--app-input-bg) 88%,var(--app-border) 12%);cursor:not-allowed}.pack-complete-dialog-place-loading{font-size:14px;color:var(--app-text-muted);margin:0}.pack-complete-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--app-border);background-color:var(--app-input-bg)}.pack-complete-dialog-btn{padding:10px 20px;font-size:14px;font-weight:600;font-family:inherit;border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.pack-complete-dialog-btn-cancel{background:var(--app-surface);border:1px solid var(--app-border);color:var(--app-text)}.pack-complete-dialog-btn-cancel:hover:not(:disabled){background:var(--app-bg);border-color:var(--app-text-muted)}.pack-complete-dialog-btn-confirm{background:#16a34a;border:none;color:#fff}.pack-complete-dialog-btn-confirm:hover:not(:disabled){background:#15803d}.pack-complete-dialog-btn:disabled{cursor:not-allowed;opacity:.7}.pack-start-packing-dialog-content{gap:20px}.pack-start-packing-dialog-hint{margin:0;font-size:14px;color:var(--app-text-muted);line-height:1.5}.pack-start-packing-dialog-fields{display:flex;flex-direction:column;gap:16px}.pack-start-packing-dialog-fields .pack-config-input{max-width:none}.pack-start-packing-dialog-confirm{background:var(--app-accent);border:none;color:#fff}.pack-start-packing-dialog-confirm:hover:not(:disabled){background:var(--app-accent-hover)}.pack-session-devices-list-section{width:100%;margin-top:24px;padding-top:24px;border-top:1px solid var(--app-border);flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.pack-session-devices-list-title{margin:0 0 12px;font-size:15px;font-weight:600;color:var(--app-text);flex-shrink:0}.pack-session-devices-list{margin:0;padding:0;list-style:none;flex:1;min-height:0;overflow-y:auto}.pack-session-device-item{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;margin-bottom:4px;font-size:14px;background:var(--app-bg);border:1px solid var(--app-border);border-radius:6px}.pack-session-device-item .pack-session-delete{flex-shrink:0}.pack-session-device-id{font-weight:600;font-family:ui-monospace,monospace;color:var(--app-text)}.pack-session-device-meta{font-size:13px;color:var(--app-text-muted)}.pack-session-devices-empty{margin:0;font-size:14px;color:var(--app-text-muted)}.packing-view{display:flex;flex-direction:column;gap:20px;width:100%;max-width:100%}.packing-view-header{flex-shrink:0}.packing-back-button{padding:8px 14px;font-size:14px;font-family:inherit;color:var(--app-text-muted);background:transparent;border:1px solid var(--app-border);border-radius:8px;cursor:pointer;transition:color .2s ease,border-color .2s ease,background .2s ease}.packing-back-button:hover{color:var(--app-accent);border-color:var(--app-accent);background:var(--app-accent-bg)}.packing-view-layout{display:flex;gap:24px;flex:1;min-height:0;overflow:hidden}.packing-boxes-column{flex:0 0 360px;display:flex;flex-direction:column;min-height:0;max-height:100%;background:var(--app-surface);border:1px solid var(--app-border);border-radius:12px;padding:20px;box-shadow:0 1px 3px var(--app-shadow)}.packing-boxes-title{margin:0 0 16px;font-size:14px;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.packing-palettes-section{flex-shrink:0;margin-bottom:16px}.packing-palettes-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.packing-palettes-header-standalone{margin-bottom:12px}.packing-palettes-label{font-size:12px;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.04em}.packing-add-palette-button{padding:6px 12px;font-size:12px;font-weight:600;font-family:inherit;color:#0d9488;background:#ccfbf1;border:1px solid #99f6e4;border-radius:6px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.packing-add-palette-button:hover:not(:disabled){background:#99f6e4;border-color:#2dd4bf}.packing-add-palette-button:disabled{opacity:.7;cursor:not-allowed}.packing-add-palette-inline{margin-left:auto}.packing-palettes-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.packing-palette-item{background:#f0fdfa;border:1px solid #99f6e4;border-radius:10px;overflow:hidden}.packing-palette-header{display:flex;align-items:center;gap:6px;min-height:36px}.packing-palette-toggle{flex:1;min-width:0;display:flex;align-items:center;gap:8px;padding:8px 10px;font-family:inherit;font-size:13px;font-weight:600;color:#0f766e;background:transparent;border:none;cursor:pointer;text-align:left;transition:background .15s ease}.packing-palette-toggle:hover{background:#0d948814}.packing-palette-chevron{flex-shrink:0;font-size:10px;color:var(--app-text-muted)}.packing-palette-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.packing-palette-count{flex-shrink:0;font-size:11px;font-weight:600;color:var(--app-text-muted);background:var(--app-border);padding:2px 8px;border-radius:6px}.packing-palette-delete{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin-right:6px;padding:0;font-size:16px;line-height:1;color:var(--app-text-muted);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:color .2s ease,background .2s ease}.packing-palette-delete:hover:not(:disabled){color:#dc2626;background:#ef44441a}.packing-palette-boxes{list-style:none;margin:0;padding:8px 10px 10px;display:flex;flex-direction:column;gap:8px;border-top:1px solid #99f6e4}.packing-palette-boxes .packing-box-item-row{margin:0}.packing-add-box-to-palette{display:block;width:calc(100% - 20px);max-width:100%;margin:8px 10px 10px;padding:8px 12px;font-size:12px;font-weight:600;font-family:inherit;color:#0d9488;background:#f0fdfa;border:1px dashed #99f6e4;border-radius:6px;cursor:pointer;transition:background .2s ease,border-color .2s ease;box-sizing:border-box}.packing-add-box-to-palette:hover:not(:disabled){background:#ccfbf1;border-color:#2dd4bf}.packing-add-box-to-palette:disabled{opacity:.7;cursor:not-allowed}.packing-unassigned-section{flex:1;min-height:0;display:flex;flex-direction:column}.packing-unassigned-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.packing-unassigned-label{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.packing-box-palette-select{flex-shrink:0;min-width:0;padding:6px 8px;font-size:12px;font-family:inherit;color:var(--app-input-text);background:var(--app-input-bg);border:1px solid var(--app-border);border-radius:6px;cursor:pointer}.packing-box-item .packing-box-palette-select{align-self:center}.packing-box-palette-select:hover{border-color:var(--app-text-muted)}.packing-box-palette-select:focus{outline:none;border-color:var(--app-accent)}.packing-boxes-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1;min-height:0;margin-bottom:12px}.packing-box-item-row{display:flex;align-items:stretch;gap:8px;min-width:0}.packing-box-item-row .packing-box-item{flex:1;min-width:0;position:relative}.packing-box-actions{position:absolute;top:6px;right:8px;z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.packing-box-actions:has(.packing-box-palette-menu){z-index:1001}.packing-box-close{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;font-size:18px;line-height:1;color:var(--app-text-muted);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:color .2s ease,background .2s ease}.packing-box-palette-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;color:var(--app-text-muted);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:color .2s ease,background .2s ease}.packing-box-palette-icon:hover{color:#0d9488;background:#f0fdfa}.packing-box-palette-icon[aria-expanded=true]{color:#0d9488;background:#ccfbf1}.packing-box-palette-menu{position:absolute;top:100%;right:0;margin-top:4px;min-width:140px;padding:4px 0;background:var(--app-surface);border:1px solid var(--app-border);border-radius:8px;box-shadow:0 4px 12px var(--app-shadow);z-index:1000;list-style:none}.packing-box-palette-menu-item{display:block;width:100%;padding:8px 12px;font-size:13px;font-family:inherit;text-align:left;color:var(--app-text);background:transparent;border:none;cursor:pointer;transition:background .15s ease}.packing-box-palette-menu-item:hover{background:var(--app-bg)}.packing-box-close:hover:not(:disabled){color:#dc2626;background:#ef44441a}.packing-box-close:disabled{opacity:.7;cursor:not-allowed}.packing-box-close .packing-box-delete-spinner{font-size:14px;animation:pack-session-delete-spin .8s linear infinite}.packing-box-item-main{display:flex;flex-direction:column;gap:8px;width:100%;padding:14px 36px 14px 14px;text-align:left;font-family:inherit;background:transparent;border:none;cursor:pointer;min-width:0}.packing-box-fill-row{display:flex;align-items:center;gap:8px;min-width:0}.packing-box-fill-row .packing-box-fill{flex:1;min-width:0}.packing-box-delete-spinner{animation:pack-session-delete-spin .8s linear infinite}.packing-add-actions{flex-shrink:0;display:flex;flex-direction:row;gap:10px;margin-top:0}.packing-add-actions .packing-add-palette-button,.packing-add-actions .packing-add-box-button{flex:1;min-width:0}.packing-add-actions .packing-add-palette-button{font-size:14px;padding:10px 16px;border-radius:8px}.packing-add-box-button{flex-shrink:0;margin-top:0;padding:10px 16px;font-size:14px;font-weight:600;font-family:inherit;color:var(--app-accent);background:var(--app-accent-bg);border:1px solid var(--app-accent);border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.packing-add-box-button:hover{background:var(--app-accent-bg);border-color:var(--app-accent-hover)}.packing-box-item{display:flex;flex-direction:column;gap:8px;text-align:left;font-family:inherit;background:var(--app-bg);border:1px solid var(--app-border);border-radius:10px;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.packing-box-item:hover{border-color:var(--app-text-muted);background:var(--app-surface)}.packing-box-item.selected{border-color:var(--app-accent);background:var(--app-accent-bg);box-shadow:0 0 0 2px var(--app-accent-bg)}.packing-box-label{font-size:14px;font-weight:600;color:var(--app-text)}.packing-box-fill{position:relative;height:24px;border-radius:6px;background:var(--app-border);overflow:hidden;display:flex;align-items:center;justify-content:center}.packing-box-fill-bar{position:absolute;left:0;top:0;bottom:0;background:var(--app-accent);border-radius:6px;transition:width .2s ease}.packing-box-item.selected .packing-box-fill-bar{background:var(--app-accent-hover)}.packing-box-fill-text{position:relative;z-index:1;font-size:12px;font-weight:600;color:var(--app-text);text-shadow:0 0 2px var(--app-surface),0 1px 2px var(--app-surface)}.packing-scan-area{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;align-items:stretch;background:var(--app-surface);border:1px solid var(--app-border);border-radius:12px;padding:32px;box-shadow:0 1px 3px var(--app-shadow);overflow:hidden}.pack-session-scan-fixed{position:sticky;top:0;z-index:1;flex-shrink:0;background:var(--app-surface);padding-bottom:20px;margin-bottom:4px;display:flex;flex-direction:column;align-items:center}.packing-scan-title{margin:0 0 24px;font-size:18px;font-weight:600;color:var(--app-text)}.packing-scan-form{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px}.packing-scan-input{width:100%;padding:14px 18px;font-size:16px;font-family:inherit;border:1px solid var(--app-border);border-radius:10px;background:var(--app-input-bg);color:var(--app-input-text);transition:border-color .2s ease,box-shadow .2s ease}.packing-scan-input::-moz-placeholder{color:var(--app-text-muted)}.packing-scan-input::placeholder{color:var(--app-text-muted)}.packing-scan-input:hover:not(:disabled){border-color:var(--app-text-muted)}.packing-scan-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-bg)}.packing-scan-submit{padding:12px 20px;font-size:15px;font-weight:600;font-family:inherit;color:#fff;background:var(--app-accent);border:none;border-radius:10px;cursor:pointer;transition:background .2s ease,opacity .2s ease}.packing-scan-submit:hover:not(:disabled){background:var(--app-accent-hover)}.packing-scan-submit:disabled{opacity:.6;cursor:not-allowed}.packing-scan-full{margin:16px 0 0;font-size:14px;color:#dc2626}.pack-session-main-fill{flex:1;min-height:0;display:flex;flex-direction:column}.device-cannot-move-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.device-cannot-move-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px var(--app-shadow),0 10px 10px -5px var(--app-shadow);max-width:520px;width:100%;max-height:min(90vh,640px);display:flex;flex-direction:column;overflow:hidden}.device-cannot-move-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border);flex-shrink:0}.device-cannot-move-title{margin:0;font-size:18px;font-weight:600;color:var(--app-text)}.device-cannot-move-close{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:20px;line-height:1;color:var(--app-text-muted);border-radius:6px;transition:background .2s ease,color .2s ease}.device-cannot-move-close:hover{background:var(--app-bg);color:var(--app-text)}.device-cannot-move-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.device-cannot-move-summary{margin:0;font-size:14px;color:var(--app-text);line-height:1.5}.device-cannot-move-status-line{margin:0;font-size:13px;color:var(--app-text-muted)}.device-cannot-move-severity-legend{margin:0;padding:12px 14px;font-size:13px;line-height:1.5;color:var(--app-text-muted);background:var(--app-input-bg);border-radius:8px;border:1px solid var(--app-border)}.device-cannot-move-rules-title{margin:0;font-size:14px;font-weight:600;color:var(--app-text)}.device-cannot-move-rules{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.device-cannot-move-rule{padding:12px 14px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-input-bg)}.device-cannot-move-rule-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px}.device-cannot-move-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:4px 8px;border-radius:6px;line-height:1.2}.device-cannot-move-badge--system{background:color-mix(in srgb,#7c3aed 18%,transparent);color:#6d28d9}.device-cannot-move-badge--critical{background:color-mix(in srgb,#dc2626 18%,transparent);color:#b91c1c}.device-cannot-move-badge--high{background:color-mix(in srgb,#ea580c 18%,transparent);color:#c2410c}.device-cannot-move-badge--low{background:color-mix(in srgb,#2563eb 16%,transparent);color:#1d4ed8}.device-cannot-move-rule-kind{font-size:12px;color:var(--app-text-muted);flex:1;min-width:140px}.device-cannot-move-rule-name{margin:0 0 4px;font-size:14px;font-weight:600;color:var(--app-text)}.device-cannot-move-rule-message{margin:0;font-size:13px;color:var(--app-text-muted);line-height:1.45}.device-cannot-move-constraints{margin:8px 0 0;padding-left:18px;font-size:12px;color:var(--app-text-muted);line-height:1.4}.device-cannot-move-footer{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--app-border);background-color:var(--app-input-bg);flex-shrink:0}.device-cannot-move-ok{padding:10px 20px;font-size:14px;font-weight:600;font-family:inherit;border-radius:8px;cursor:pointer;background:var(--app-accent);border:none;color:#fff;transition:background .2s ease}.device-cannot-move-ok:hover{background:var(--app-accent-hover)}.pack-meters-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:pack-dialog-fadeIn .2s ease-out}@keyframes pack-dialog-fadeIn{0%{opacity:0}to{opacity:1}}.pack-meters-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:440px;width:100%;display:flex;flex-direction:column;animation:pack-dialog-slideUp .3s ease-out;overflow:hidden}@keyframes pack-dialog-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pack-meters-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.pack-meters-dialog-title{margin:0;font-size:20px;font-weight:600;color:#1f2937}.pack-meters-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.pack-meters-dialog-close:hover{background-color:var(--app-bg);color:#1f2937}.pack-meters-dialog-content{padding:24px}.pack-meters-dialog-intro{margin:0 0 20px;font-size:15px;color:#374151;line-height:1.5}.pack-meters-dialog-options{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.pack-meters-dialog-option{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;background:var(--app-surface);border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:15px;font-weight:500;color:#374151;text-align:center}.pack-meters-dialog-option:hover{background:var(--app-bg);border-color:#d1d5db}.pack-meters-dialog-option-selected{background:#eff6ff;border-color:var(--app-accent);color:var(--app-accent-deep)}.pack-meters-dialog-option-selected .pack-meters-dialog-option-icon{color:var(--app-accent)}.pack-meters-dialog-option-icon{display:flex;align-items:center;justify-content:center;color:#6b7280}.pack-meters-dialog-option-label{display:block}.pack-meters-dialog-confirm-hint{margin:0;font-size:13px;color:#6b7280;line-height:1.4}.pack-meters-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:var(--app-input-bg)}.pack-meters-dialog-btn{padding:.5rem 1rem;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease;font-family:inherit;border:none}.pack-meters-dialog-btn-cancel{background:var(--app-surface);color:#374151;border:1px solid #d1d5db}.pack-meters-dialog-btn-cancel:hover{background:var(--app-surface);border-color:#9ca3af}.pack-meters-dialog-btn-confirm{background:var(--app-accent);color:#fff}.pack-meters-dialog-btn-confirm:hover:not(:disabled){background:var(--app-accent-hover);box-shadow:0 2px 4px var(--app-accent-alpha-30)}.pack-meters-dialog-btn-confirm:disabled{background:#9ca3af;cursor:not-allowed;opacity:.7}@media(prefers-color-scheme:dark){.pack-meters-dialog{background:#1f2937}.pack-meters-dialog-header{border-bottom-color:#374151}.pack-meters-dialog-title{color:var(--app-surface)}.pack-meters-dialog-close{color:#9ca3af}.pack-meters-dialog-close:hover{background:#374151;color:var(--app-surface)}.pack-meters-dialog-content{background:transparent}.pack-meters-dialog-intro{color:#e5e7eb}.pack-meters-dialog-option{background:#374151;border-color:#4b5563;color:#e5e7eb}.pack-meters-dialog-option:hover{background:#4b5563}.pack-meters-dialog-option-selected{background:#1e3a8a;border-color:var(--app-accent);color:var(--app-accent-hover)}.pack-meters-dialog-option-icon,.pack-meters-dialog-confirm-hint{color:#9ca3af}.pack-meters-dialog-footer{border-top-color:#374151;background-color:var(--app-input-bg)}.pack-meters-dialog-btn-cancel{background:#374151;color:#e5e7eb;border-color:#4b5563}.pack-meters-dialog-btn-cancel:hover{background:#4b5563}}.scan-waiting-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;background-color:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:scan-waiting-fadeIn .2s ease-out}@keyframes scan-waiting-fadeIn{0%{opacity:0}to{opacity:1}}.scan-waiting-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px #00000026,0 10px 10px -5px #00000014;max-width:420px;width:100%;padding:28px 24px;text-align:center;animation:scan-waiting-slideUp .25s ease-out}@keyframes scan-waiting-slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.scan-waiting-title{margin:0 0 12px;font-size:18px;font-weight:600;color:#1f2937}.scan-waiting-desc{margin:0 0 20px;font-size:14px;line-height:1.5;color:#4b5563}.scan-waiting-countdown{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;margin-bottom:20px;font-size:28px;font-weight:700;color:var(--app-accent);background:#eff6ff;border-radius:50%;border:2px solid #bfdbfe}.scan-waiting-actions{display:flex;flex-direction:column;gap:10px}.scan-waiting-simulate{display:block;width:100%;padding:10px 16px;font-size:14px;font-weight:500;color:#fff;background:var(--app-accent);border:1px solid var(--app-accent-hover);border-radius:8px;cursor:pointer;font-family:inherit;transition:background-color .2s,border-color .2s}.scan-waiting-simulate:hover{background:var(--app-accent-hover);border-color:var(--app-accent-hover)}.scan-waiting-close{display:block;width:100%;padding:10px 16px;font-size:14px;font-weight:500;color:#4b5563;background:var(--app-bg);border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;font-family:inherit;transition:background-color .2s,border-color .2s,color .2s}.scan-waiting-close:hover{background:#e5e7eb;border-color:#d1d5db;color:#1f2937}@media(prefers-color-scheme:dark){.scan-waiting-overlay{background-color:#00000080}.scan-waiting-dialog{background:#1f2937;box-shadow:0 20px 25px -5px #00000059}.scan-waiting-title{color:var(--app-surface)}.scan-waiting-desc{color:#9ca3af}.scan-waiting-countdown{color:var(--app-accent);background:var(--app-accent-alpha-15);border-color:var(--app-accent)}.scan-waiting-simulate{background:var(--app-accent-hover);border-color:var(--app-accent-hover)}.scan-waiting-simulate:hover{background:var(--app-accent-hover);border-color:var(--app-accent-deep)}.scan-waiting-close{color:#e5e7eb;background:#374151;border-color:#4b5563}.scan-waiting-close:hover{background:#4b5563;border-color:#6b7280;color:var(--app-surface)}}.add-new-devices-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.add-new-devices-content{flex:1;padding:28px 24px;max-width:1200px;margin:0 auto;width:100%}.add-new-devices-layout{display:flex;gap:28px;min-height:400px}.add-new-devices-sidebar{flex:0 0 var(--app-sidebar-expanded-width);display:flex;flex-direction:column;gap:10px}.add-new-devices-sidebar-title{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.add-new-devices-sidebar-loading,.add-new-devices-sidebar-empty{margin:0;font-size:.9rem;color:var(--app-text-muted)}.add-new-devices-sidebar-error{margin:0;font-size:.9rem;color:#d04646;font-weight:500}.add-new-devices-sidebar-group{display:flex;flex-direction:column;gap:10px}.add-new-devices-sidebar-separator{display:flex;align-items:center;gap:10px;margin:4px 0 2px;flex-shrink:0}.add-new-devices-sidebar-separator-line{flex:1;height:1px;background:var(--app-border)}.add-new-devices-sidebar-separator-label{font-size:11px;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.add-new-devices-sidebar-item{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:10px;cursor:pointer;text-align:left;font-family:inherit;transition:all .2s ease;box-shadow:0 1px 3px var(--app-shadow)}.add-new-devices-sidebar-item:hover{border-color:var(--app-accent);box-shadow:0 4px 12px var(--app-shadow)}.add-new-devices-sidebar-item.selected{border-color:var(--app-accent);background:var(--app-accent-bg);border-left-width:4px;box-shadow:0 4px 12px var(--app-shadow)}.add-new-devices-sidebar-item.disabled{opacity:.55;cursor:not-allowed;background:var(--app-bg);border-color:var(--app-border)}.add-new-devices-sidebar-item.disabled:hover{border-color:var(--app-border);box-shadow:0 1px 3px var(--app-shadow)}.add-new-devices-sidebar-item.disabled .add-new-devices-sidebar-icon{background:var(--app-surface);color:var(--app-text-muted)}.add-new-devices-sidebar-item.disabled .add-new-devices-sidebar-label,.add-new-devices-sidebar-item.disabled .add-new-devices-sidebar-desc{color:var(--app-text-muted)}.add-new-devices-sidebar-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--app-bg);border-radius:8px;color:var(--app-text-muted);flex-shrink:0}.add-new-devices-sidebar-item:hover .add-new-devices-sidebar-icon,.add-new-devices-sidebar-item.selected .add-new-devices-sidebar-icon{background:var(--app-accent-bg);color:var(--app-accent)}.add-new-devices-sidebar-text{display:flex;flex-direction:column;gap:2px;min-width:0}.add-new-devices-sidebar-label{font-size:15px;font-weight:600;color:var(--app-text)}.add-new-devices-sidebar-desc{font-size:13px;color:var(--app-text-muted);line-height:1.3}.add-new-devices-sidebar-item.selected .add-new-devices-sidebar-label{color:var(--app-accent);font-weight:700}.add-new-devices-sidebar-item.selected .add-new-devices-sidebar-desc{color:var(--app-text)}.add-new-devices-panel{flex:1;min-width:0;background:var(--app-surface);border-radius:12px;padding:28px;box-shadow:0 1px 3px var(--app-shadow);border:1px solid var(--app-border)}.add-new-devices-panel-title{margin:0 0 6px;font-size:18px;font-weight:700;color:var(--app-text)}.add-new-devices-panel-subtitle{margin:0 0 24px;font-size:14px;color:var(--app-text-muted)}.add-new-devices-panel-options{display:flex;flex-direction:column;gap:12px}.add-new-devices-panel-card{display:flex;align-items:center;gap:18px;padding:20px 22px;background:var(--app-bg);border:1px solid var(--app-border);border-radius:10px;cursor:pointer;text-align:left;font-family:inherit;transition:all .2s ease}.add-new-devices-panel-card:hover{border-color:var(--app-accent);background:var(--app-accent-bg);box-shadow:0 4px 12px var(--app-shadow);transform:translate(4px)}.add-new-devices-panel-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--app-surface);border-radius:10px;color:var(--app-accent);flex-shrink:0;border:1px solid var(--app-border)}.add-new-devices-panel-card:hover .add-new-devices-panel-card-icon{border-color:var(--app-accent);background:var(--app-accent-bg)}.add-new-devices-panel-card-content{flex:1;min-width:0}.add-new-devices-panel-card-label{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--app-text)}.add-new-devices-panel-card-description{margin:0;font-size:14px;color:var(--app-text-muted);line-height:1.4}.add-new-devices-panel-card-arrow{color:var(--app-text-muted);flex-shrink:0;transition:transform .2s ease,color .2s ease}.add-new-devices-panel-card:hover .add-new-devices-panel-card-arrow{transform:translate(4px);color:var(--app-accent)}.add-new-devices-panel-placeholder{display:flex;align-items:center;justify-content:center;min-height:280px;padding:24px}.add-new-devices-panel-placeholder p{margin:0;font-size:15px;color:var(--app-text-muted);text-align:center;max-width:280px}@media(max-width:768px){.add-new-devices-layout{flex-direction:column}.add-new-devices-sidebar{flex:0 0 auto}.add-new-devices-sidebar-item{flex-direction:row}}.meter-search-container{display:flex;align-items:center;gap:8px;width:600px;min-width:0}.meter-search-input-wrap{position:relative;flex:1;min-width:0}.meter-search-input{display:block;width:100%;box-sizing:border-box;padding:12px 18px;border:1px solid var(--app-border);border-radius:6px;font-size:16px;color:var(--app-input-text);background:var(--app-input-bg);transition:border-color .2s ease,box-shadow .2s ease}.meter-search-input-wrap-has-clear .meter-search-input{padding-right:40px}.meter-search-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:var(--app-text-muted);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s,color .2s;font-family:inherit}.meter-search-clear:hover{background-color:var(--app-bg);color:var(--app-text)}.meter-search-button{display:flex;align-items:center;justify-content:center;padding:10px 16px;background-color:var(--app-accent);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease,transform .1s ease;flex-shrink:0}.meter-search-button:hover{background-color:var(--app-accent-hover);transform:translateY(-1px)}.meter-search-button:active{transform:translateY(0);background-color:var(--app-accent-hover)}.meter-search-scan-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;color:var(--app-text);background-color:var(--app-surface);border:1px solid var(--app-border);border-radius:6px;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s;font-family:inherit;flex-shrink:0}.meter-search-scan-btn:hover:not(:disabled){background-color:var(--app-bg);border-color:var(--app-text-muted);color:var(--app-text)}.meter-search-scan-btn-disabled,.meter-search-scan-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.meter-search-input::-moz-placeholder{color:var(--app-text-muted)}.meter-search-input::placeholder{color:var(--app-text-muted)}.meter-search-input:hover{border-color:var(--app-text-muted)}.meter-search-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-bg)}.containers-list-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.containers-list-content{flex:1;padding:24px;width:100%;max-width:100%;box-sizing:border-box}.containers-list-content--embedded{padding:0 24px 24px;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.containers-list-page.meter-table-container,.containers-list-page .meter-table-layout,.containers-list-page .meter-table-main-content{min-height:0}.containers-list-page .meter-table-main-content{flex:1}.containers-table-wrapper.meter-table-wrapper{flex:1;min-height:0;margin:0;width:100%;overflow-x:auto;overflow-y:auto}.containers-list-loading,.containers-list-error,.containers-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;text-align:center;color:var(--app-text-muted)}.containers-list-spinner{width:40px;height:40px;border:3px solid var(--app-border);border-top-color:var(--app-accent);border-radius:50%;animation:containers-list-spin .8s linear infinite}@keyframes containers-list-spin{to{transform:rotate(360deg)}}.containers-list-error p{margin:0;color:#b91c1c}.containers-list-retry{padding:.5rem 1rem;background:var(--app-accent);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;font-family:inherit}.containers-list-retry:hover{background:var(--app-accent-hover)}.containers-list-empty p{margin:0}.containers-table{min-width:600px;width:100%;table-layout:fixed}.containers-table-th-expand{width:3rem;padding:.75rem .5rem!important;text-align:center;vertical-align:middle}.containers-table-td-expand{width:3rem;padding:.5rem!important;text-align:center;vertical-align:middle}.containers-table-expand-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--app-border);border-radius:6px;background:var(--app-surface);color:var(--app-text);font-size:1.25rem;font-weight:600;line-height:1;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;font-family:inherit}.containers-table-expand-btn:hover{background:var(--app-bg);border-color:var(--app-text-muted)}.containers-table-expand-btn[aria-expanded=true]{background:var(--app-accent-bg);border-color:var(--app-accent);color:var(--app-accent)}.containers-table-expand-icon{display:block}.containers-table-name{font-weight:600;color:var(--app-text)}.containers-table-row-clickable{cursor:pointer}.containers-table-row-expanded{background-color:var(--app-bg)}.containers-table-detail-row{background-color:var(--app-bg);border-bottom:1px solid var(--app-border)}.containers-table-detail-row:hover{background-color:var(--app-bg)}.containers-table-detail-cell{padding:0!important;vertical-align:top;border-bottom:1px solid var(--app-border);width:100%;box-sizing:border-box}.container-detail{padding:1rem 1.5rem;width:100%;min-width:0;box-sizing:border-box}.container-detail-grid{display:flex;flex-wrap:wrap;gap:1.5rem;width:100%;min-width:0}.container-detail-block{flex:1;min-width:200px;background:var(--app-surface);border-radius:8px;padding:1rem;border:1px solid var(--app-border);box-sizing:border-box}.container-detail-block-title{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:var(--app-text)}.container-detail-dl{margin:0;display:flex;flex-direction:column;gap:.5rem}.container-detail-row{display:flex;gap:.75rem;font-size:.875rem}.container-detail-row dt{margin:0;min-width:7rem;color:var(--app-text-muted);flex-shrink:0}.container-detail-row dd{margin:0;color:var(--app-text);word-break:break-word}.container-detail-status{font-weight:500}.container-detail-list{margin:0;padding-left:1.25rem;max-height:8rem;overflow-y:auto}.container-detail-list li{margin:.25rem 0}.container-detail-list-more{color:var(--app-text-muted);font-style:italic}.containers-table .meter-table-status-received{background-color:#dbeafe;color:var(--app-accent-deep)}.containers-table .meter-table-status-stocked{background-color:#d1fae5;color:#065f46}.containers-table .meter-table-status-shipped{background-color:#e0e7ff;color:#3730a3}.shipments-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.shipments-page.meter-table-container,.shipments-page .meter-table-layout,.shipments-page .meter-table-main-content{min-height:0}.shipments-page .meter-table-main-content{flex:1}.shipments-list-content{flex:1;padding:24px;width:100%;max-width:100%;box-sizing:border-box}.shipments-list-content--embedded{padding:0 24px 24px;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.shipments-list-loading,.shipments-list-error,.shipments-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;text-align:center;color:var(--app-text-muted)}.shipments-list-spinner{width:40px;height:40px;border:3px solid var(--app-border);border-top-color:var(--app-accent);border-radius:50%;animation:shipments-list-spin .8s linear infinite}@keyframes shipments-list-spin{to{transform:rotate(360deg)}}.shipments-list-error p{margin:0;color:#b91c1c}.shipments-list-retry{padding:.5rem 1rem;background:var(--app-accent);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;font-family:inherit}.shipments-list-retry:hover{background:var(--app-accent-hover)}.shipments-list-empty p{margin:0}.shipments-table-wrapper{flex:1;min-height:0;margin:0;width:100%;overflow-x:auto;overflow-y:auto}.shipments-table{min-width:760px;width:100%;table-layout:fixed}.shipments-table-th-expand{width:3rem;padding:.75rem .5rem!important;text-align:center;vertical-align:middle}.shipments-table-td-expand{width:3rem;padding:.5rem!important;text-align:center;vertical-align:middle}.shipments-table-expand-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--app-border);border-radius:6px;background:var(--app-surface);color:var(--app-text);font-size:1.25rem;font-weight:600;line-height:1;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;font-family:inherit}.shipments-table-expand-btn:hover{background:var(--app-bg);border-color:var(--app-text-muted)}.shipments-table-expand-btn[aria-expanded=true]{background:var(--app-accent-bg);border-color:var(--app-accent);color:var(--app-accent)}.shipments-table-expand-icon{display:block}.shipments-table-name{font-weight:600;color:var(--app-text)}.shipments-table-row-clickable{cursor:pointer}.shipments-table-row-expanded{background-color:var(--app-bg)}.shipments-table-detail-row{background-color:var(--app-bg);border-bottom:1px solid var(--app-border)}.shipments-table-detail-row:hover{background-color:var(--app-bg)}.shipments-table-detail-cell{padding:0!important;vertical-align:top;border-bottom:1px solid var(--app-border);width:100%;box-sizing:border-box}.shipment-detail{padding:1rem 1.5rem;width:100%;min-width:0;box-sizing:border-box}.shipment-detail-grid{display:flex;flex-wrap:wrap;gap:1.5rem;width:100%;min-width:0}.shipment-detail-block{flex:1;min-width:200px;background:var(--app-surface);border-radius:8px;padding:1rem;border:1px solid var(--app-border);box-sizing:border-box}.shipment-detail-block-title{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:var(--app-text)}.shipment-detail-dl{margin:0;display:flex;flex-direction:column;gap:.5rem}.shipment-detail-row{display:flex;gap:.75rem;font-size:.875rem}.shipment-detail-row dt{margin:0;min-width:7rem;color:var(--app-text-muted);flex-shrink:0}.shipment-detail-row dd{margin:0;color:var(--app-text);word-break:break-word}.shipment-detail-status{font-weight:500}.shipment-detail-list{margin:0;padding-left:1.25rem;max-height:8rem;overflow-y:auto}.shipment-detail-list li{margin:.25rem 0}.shipment-detail-list-more{color:var(--app-text-muted);font-style:italic}.shipments-table .meter-table-status-loading{background-color:#fef3c7;color:#92400e}.shipments-table .meter-table-status-ontheway{background-color:#e0e7ff;color:#3730a3}.shipments-table .meter-table-status-received{background-color:#dbeafe;color:var(--app-accent-deep)}.receive-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden}.receive-page-content{flex:1;padding:24px;overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:28px}.receive-page-sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}@media(max-width:900px){.receive-page-sections-grid{grid-template-columns:1fr}}.receive-page-section{background:var(--app-surface);border:1px solid var(--app-border);border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px var(--app-shadow)}.receive-page-section-title{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--app-text)}.receive-page-section-desc{margin:0 0 16px;font-size:.9rem;color:var(--app-text-muted)}.receive-page-muted{margin:0;color:var(--app-text-muted);font-size:14px}.receive-page-error{margin:0;color:#dc2626;font-size:14px}.receive-page-empty{margin:0;color:var(--app-text-muted);font-size:.95rem}.receive-page-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.receive-page-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;background:var(--app-bg);border:1px solid var(--app-border);border-radius:8px;flex-wrap:wrap}.receive-page-item-main{display:flex;flex-direction:column;gap:4px;min-width:0}.receive-page-item-primary{font-weight:600;font-size:1rem;color:var(--app-text)}.receive-page-item-meta{font-size:.85rem;color:var(--app-text-muted)}.receive-page-item-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;flex-shrink:0}.receive-page-btn{flex-shrink:0;padding:8px 18px;font-size:14px;font-weight:600;font-family:inherit;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease,opacity .2s ease}.receive-page-btn:disabled{opacity:.7;cursor:not-allowed}.receive-page-btn-accept{color:#fff;background:#16a34a}.receive-page-btn-accept:hover:not(:disabled){background:#15803d}.receive-page-btn-receive{color:#fff;background:var(--app-accent)}.receive-page-btn-receive:hover:not(:disabled){background:var(--app-accent-hover)}.receive-page-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.receive-page-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px var(--app-shadow),0 10px 10px -5px var(--app-shadow);max-width:440px;width:100%;display:flex;flex-direction:column;overflow:hidden}.receive-page-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border)}.receive-page-dialog-title{margin:0;font-size:18px;font-weight:600;color:var(--app-text)}.receive-page-dialog-close{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:20px;line-height:1;color:var(--app-text-muted);border-radius:6px;transition:background .2s ease,color .2s ease}.receive-page-dialog-close:hover:not(:disabled){background:var(--app-bg);color:var(--app-text)}.receive-page-dialog-close:disabled{cursor:not-allowed;opacity:.6}.receive-page-dialog-content{padding:24px;display:flex;flex-direction:column;gap:16px}.receive-page-dialog-summary{margin:0;font-size:14px;font-weight:600;color:var(--app-text)}.receive-page-dialog-info{display:grid;gap:8px 20px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin:0}.receive-page-dialog-info div{display:flex;flex-direction:column;gap:2px}.receive-page-dialog-info dt{margin:0;font-size:12px;font-weight:500;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.receive-page-dialog-info dd{margin:0;font-size:14px;font-weight:500;color:var(--app-text)}.receive-page-dialog-place{padding-top:8px;border-top:1px solid var(--app-border)}.receive-page-dialog-place-label{display:block;font-size:14px;font-weight:600;color:var(--app-text);margin-bottom:8px}.receive-page-dialog-place-select{width:100%;max-width:320px;padding:10px 12px;font-size:14px;font-family:inherit;border:1px solid var(--app-border);border-radius:8px;background:var(--app-input-bg);color:var(--app-input-text)}.receive-page-dialog-place-loading{font-size:14px;color:var(--app-text-muted);margin:0}.receive-page-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--app-border);background-color:var(--app-input-bg)}.receive-page-dialog-btn{padding:10px 20px;font-size:14px;font-weight:600;font-family:inherit;border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.receive-page-dialog-btn-cancel{background:var(--app-surface);border:1px solid var(--app-border);color:var(--app-text)}.receive-page-dialog-btn-cancel:hover:not(:disabled){background:var(--app-bg);border-color:var(--app-text-muted)}.receive-page-dialog-btn-confirm{background:var(--app-accent);border:none;color:#fff}.receive-page-dialog-btn-confirm:hover:not(:disabled){background:var(--app-accent-hover)}.receive-page-dialog-btn:disabled{cursor:not-allowed;opacity:.7}.testing-ui-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:testingUiFadeIn .2s ease-out}@keyframes testingUiFadeIn{0%{opacity:0}to{opacity:1}}.testing-ui-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:1120px;height:90vh;max-height:880px;display:flex;flex-direction:column;animation:testingUiSlideUp .3s ease-out;overflow:hidden}@keyframes testingUiSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.testing-ui-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.testing-ui-dialog-title{margin:0;font-size:18px;font-weight:600;color:#1f2937}.testing-ui-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.testing-ui-dialog-close:hover{background-color:var(--app-bg);color:#1f2937}.testing-ui-dialog-content{flex:1;min-height:0;display:flex;flex-direction:column}.testing-ui-dialog-iframe{flex:1;width:100%;border:none;border-radius:0 0 8px 8px}.testing-ui-dialog-embedded{max-width:none;max-height:none;height:100%;min-height:320px;box-shadow:0 1px 3px #0000001a}.testing-ui-grid-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:testingUiGridFadeIn .2s ease-out}@keyframes testingUiGridFadeIn{0%{opacity:0}to{opacity:1}}.testing-ui-grid-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:1440px;height:92vh;max-height:960px;display:flex;flex-direction:column;animation:testingUiGridSlideUp .3s ease-out;overflow:hidden}@keyframes testingUiGridSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.testing-ui-grid-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.testing-ui-grid-dialog-title{margin:0;font-size:18px;font-weight:600;color:#1f2937}.testing-ui-grid-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.testing-ui-grid-dialog-close:hover{background-color:var(--app-bg);color:#1f2937}.testing-ui-grid-dialog-content{flex:1;min-height:0;display:grid;gap:12px;padding:12px;overflow:hidden}.testing-ui-grid-dialog-content--count-1{grid-template-columns:1fr;grid-template-rows:1fr}.testing-ui-grid-dialog-content--count-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.testing-ui-grid-dialog-content--count-3{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.testing-ui-grid-dialog-content--count-3 .testing-ui-grid-dialog-cell:last-child{grid-column:1 / -1}.testing-ui-grid-dialog-content--count-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.testing-ui-grid-dialog-cell{min-height:0;overflow:hidden;border-radius:8px;border:1px solid #e5e7eb}.testing-page{display:flex;flex-direction:column;height:100%;min-height:0}.testing-page-content{flex:1;overflow:auto;padding:1.5rem;display:flex;align-items:center;justify-content:center;min-height:0}.testing-page-layout{width:100%;max-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.testing-page-input-wrap{width:100%;max-width:720px}.testing-page-card{background:var(--app-surface);border-radius:12px;box-shadow:0 1px 3px var(--app-shadow);padding:2rem 2.25rem}.testing-page-card--input{flex-shrink:0}.testing-page-label{display:block;font-weight:600;color:var(--app-text);margin-bottom:.75rem}.testing-page-actions{display:flex;gap:1rem;align-items:center}.testing-page-actions .testing-page-floating-field{flex:1;min-width:0}.testing-page-card--input .floating-field-label{left:1.125rem}.testing-page-card--input .floating-field-input:not(:-moz-placeholder)+.floating-field-label{left:.875rem;font-size:.8125rem}.testing-page-card--input .floating-field-input:focus+.floating-field-label,.testing-page-card--input .floating-field-input:not(:placeholder-shown)+.floating-field-label{left:.875rem;font-size:.8125rem}.testing-page-input{flex:1;min-height:3.25rem;padding:.875rem 1.125rem;border:1px solid var(--app-border);border-radius:8px;font-size:1.25rem;background:var(--app-input-bg);color:var(--app-input-text)}.testing-page-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent-bg)}.testing-page-input:disabled{background-color:color-mix(in srgb,var(--app-input-bg) 88%,var(--app-border) 12%);cursor:not-allowed}.testing-page-start-btn{padding:.875rem 1.75rem;min-height:3.25rem;background:var(--app-accent);color:#fff;border:none;border-radius:8px;font-size:1.125rem;font-weight:600;cursor:pointer;white-space:nowrap}.testing-page-start-btn:hover:not(:disabled){background:var(--app-accent-hover)}.testing-page-start-btn:disabled{background:#9ca3af;cursor:not-allowed}.testing-page-error{margin-top:.75rem;color:#dc2626;font-size:.875rem}.testing-page-list-section{background:var(--app-surface);border-radius:8px;box-shadow:0 1px 3px var(--app-shadow);padding:1.25rem 1.5rem;min-height:120px}.testing-page-list-title{font-size:1rem;font-weight:600;color:var(--app-text);margin:0 0 .75rem}.testing-page-list-empty,.testing-page-list-error{color:var(--app-text-muted, #6b7280);font-size:.9375rem;margin:0}.testing-page-list-error{color:#dc2626}.testing-page-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.testing-page-list-item{border-bottom:1px solid var(--app-border, #e5e7eb);font-size:.9375rem}.testing-page-list-item:last-child{border-bottom:none}.testing-page-list-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;background:none;border:none;cursor:pointer;font:inherit;color:inherit;text-align:left}.testing-page-list-row:hover{background:var(--app-bg-hover, rgba(0, 0, 0, .04))}.testing-page-list-summary{display:flex;flex-direction:column;gap:.2rem;min-width:0;flex:1}.testing-page-list-din{font-weight:600;color:var(--app-text);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.testing-page-list-chevron{flex-shrink:0;font-size:.7rem;color:var(--app-text-muted, #6b7280);transition:transform .2s ease}.testing-page-list-chevron--open{transform:rotate(180deg)}.testing-page-list-details{margin:0 0 1rem .75rem;padding:1.25rem 1.25rem 1.25rem 1rem;background:var(--app-bg, #f8fafc);border-radius:8px;border:1px solid var(--app-border, #e2e8f0)}.testing-detail{display:flex;flex-direction:column;gap:1.5rem}.testing-detail-section{display:flex;flex-direction:column;gap:.75rem}.testing-detail-section-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--app-text-muted, #64748b);margin:0;padding-bottom:.35rem;border-bottom:1px solid var(--app-border, #e2e8f0)}.testing-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem 1.5rem}.testing-detail-field{display:flex;flex-direction:column;gap:.2rem}.testing-detail-field--full{grid-column:1 / -1}.testing-detail-label{font-size:.75rem;font-weight:500;color:var(--app-text-muted, #64748b);margin:0}.testing-detail-value{font-size:.9375rem;font-weight:500;color:var(--app-text);margin:0}.testing-detail-value--mono{font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,monospace;font-variant-numeric:tabular-nums;letter-spacing:.02em}.testing-detail-result{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:.2rem .5rem;border-radius:4px;font-size:.8125rem;font-weight:600}.testing-detail-result--pass{background:#dcfce7;color:#166534}.testing-detail-result--fail{background:#fee2e2;color:#991b1b}.testing-detail-table-wrap{overflow-x:auto;border-radius:6px;border:1px solid var(--app-border, #e2e8f0);background:var(--app-surface, #fff)}.testing-detail-table{width:100%;min-width:240px;border-collapse:collapse;font-size:.875rem}.testing-detail-table th,.testing-detail-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--app-border, #e2e8f0)}.testing-detail-table th{font-weight:600;color:var(--app-text-muted, #64748b);background:var(--app-bg, #f8fafc);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.testing-detail-table thead th{border-bottom:2px solid var(--app-border, #e2e8f0)}.testing-detail-table tbody th{font-weight:500;color:var(--app-text);text-transform:none;letter-spacing:0}.testing-detail-table tbody tr:last-child th,.testing-detail-table tbody tr:last-child td{border-bottom:none}.testing-detail-table td{color:var(--app-text);font-variant-numeric:tabular-nums}.testing-page-list-badge{font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:4px}.testing-page-list-badge--passed{background:#dcfce7;color:#166534}.testing-page-list-badge--failed{background:#fee2e2;color:#991b1b}.testing-page-list-meta{color:var(--app-text-muted, #6b7280);font-size:.8125rem}.testing-performed-page .testing-performed-page-list{margin:0 1.5rem 1.5rem;flex:1;min-height:0;overflow:auto}.meter-details-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.meter-details-dialog{background:var(--app-surface);border-radius:8px;box-shadow:0 20px 25px -5px var(--app-shadow),0 10px 10px -5px var(--app-shadow);max-width:1100px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.meter-details-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border)}.meter-details-dialog-title{margin:0;font-size:20px;font-weight:600;color:var(--app-text)}.meter-details-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--app-text-muted);display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.meter-details-dialog-close:hover{background-color:var(--app-bg);color:var(--app-text)}.meter-details-dialog-content{flex:1;overflow-y:auto;padding:24px}.meter-details-section{margin-bottom:32px}.meter-details-section:last-child{margin-bottom:0}.meter-details-section-title{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--app-text);text-transform:uppercase;letter-spacing:.05em}.meter-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.meter-details-item{display:flex;flex-direction:column;gap:4px}.meter-details-label{font-size:12px;font-weight:500;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.meter-details-value{font-size:14px;color:var(--app-text);word-break:break-word}.meter-details-status{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize;width:-moz-fit-content;width:fit-content}.meter-details-status-received{background-color:#dbeafe;color:var(--app-accent-deep)}.meter-details-status-notreceived{background-color:#fee2e2;color:#dc2626}.meter-details-status-intest{background-color:#fef3c7;color:#92400e}.meter-details-status-stocked{background-color:#d1fae5;color:#065f46}.meter-details-status-shipped{background-color:#fef9c3;color:#854d0e}.meter-details-status-installed{background-color:#f3e8ff;color:#6b21a8}.meter-details-status-unknown{background-color:var(--app-border);color:var(--app-text-muted)}.meter-details-info{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.meter-details-table-wrapper{overflow-x:auto;border-radius:6px;border:1px solid var(--app-border)}.meter-details-table{width:100%;border-collapse:collapse;background:var(--app-surface)}.meter-details-table thead{background-color:var(--app-bg);border-bottom:2px solid var(--app-border)}.meter-details-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.meter-details-table tbody tr{border-bottom:1px solid var(--app-border);transition:background-color .15s ease}.meter-details-table tbody tr:hover{background-color:var(--app-bg)}.meter-details-table tbody tr:last-child{border-bottom:none}.meter-details-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--app-text)}.meter-details-table td:first-child{font-weight:500;color:var(--app-text-muted)}.meter-details-transaction-row-expandable{cursor:pointer}.meter-details-transaction-row-expandable:hover{background-color:var(--app-accent-bg)!important}.meter-details-expand-icon{display:inline-block;width:1rem;margin-right:.5rem;font-size:.65rem;color:var(--app-text-muted)}.meter-details-transaction-detail-row td{padding:0;vertical-align:top;border-bottom:1px solid var(--app-border);background-color:var(--app-bg)}.meter-details-test-result-detail{padding:1rem 1rem 1rem 2.5rem}.meter-details-test-result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem 1.5rem}.meter-details-status-testpassed{background-color:#d1fae5;color:#065f46}.meter-details-status-testfailed{background-color:#fee2e2;color:#991b1b}.meter-details-notes{padding:12px;background-color:var(--app-bg);border-radius:6px;border:1px solid var(--app-border);font-size:14px;color:var(--app-text);white-space:pre-wrap;word-break:break-word}.meter-details-communication-modules{display:flex;flex-direction:column;gap:20px}.meter-details-communication-module-card{padding:16px;background-color:var(--app-bg);border-radius:8px;border:1px solid var(--app-border)}.meter-details-communication-module-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--app-border)}.meter-details-communication-module-code{font-weight:600;font-size:14px;color:var(--app-text)}.meter-details-communication-module-notes{margin-top:12px;padding-top:12px;border-top:1px solid var(--app-border);display:flex;flex-direction:column;gap:4px}.meter-details-dialog-footer{padding:16px 24px;border-top:1px solid var(--app-border);display:flex;justify-content:flex-end}.meter-details-dialog-button{padding:.5rem 1.5rem;background-color:var(--app-accent);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.meter-details-dialog-button:hover,.meter-details-dialog-button:active{background-color:var(--app-accent-hover)}.meter-details-loading{padding:1rem;color:var(--app-text-muted);font-style:italic}.meter-details-error{padding:1rem;color:#dc2626;background-color:#ef44441a;border-radius:6px;margin:0 0 1rem;border:1px solid rgba(239,68,68,.3)}.meter-details-page-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--app-border)}.meter-details-page-back{display:inline-block;margin-bottom:.75rem;color:var(--app-accent);text-decoration:none;font-size:.875rem}.meter-details-page-back:hover{text-decoration:underline}.meter-details-page-title{margin:0 0 .25rem;font-size:1.5rem;font-weight:600;color:var(--app-text)}.meter-details-page-din{margin:0;font-size:.875rem;color:var(--app-text-muted)}.meter-details-page-content{background:var(--app-surface);border-radius:8px;border:1px solid var(--app-border);overflow:hidden}.meter-details-page-content .meter-details-dialog-content{max-height:none}.meter-card{background:var(--app-surface);border-radius:8px;padding:12px;margin-bottom:8px;box-shadow:0 1px 3px var(--app-shadow);cursor:pointer;transition:all .2s ease;border-left:3px solid var(--app-accent)}.meter-card-collapsed{padding:12px}.meter-card-collapsed .meter-card-header{margin-bottom:0;padding-bottom:0}.meter-card:hover{box-shadow:0 4px 6px var(--app-shadow);transform:translateY(-2px)}.meter-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:none}.meter-card-header-expanded{border-bottom:1px solid var(--app-border)}.meter-card-header-right{display:flex;align-items:center;gap:8px}.meter-card-toggle{background:var(--app-bg);border:1px solid var(--app-border);border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:600;color:var(--app-text-muted);transition:all .2s ease;padding:0;line-height:1}.meter-card-toggle:hover{background:var(--app-border);color:var(--app-text)}.meter-card-serial-expanded{display:flex;justify-content:space-between;font-size:12px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--app-border)}.meter-card-code{margin:0;font-size:14px;font-weight:600;color:var(--app-text)}.meter-card-serial{font-size:11px;color:var(--app-text-muted);font-weight:400}.meter-card-body{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.meter-card-info{display:flex;justify-content:space-between;font-size:12px}.meter-card-label{color:var(--app-text-muted);font-weight:500}.meter-card-value{color:var(--app-text);font-weight:400}.meter-card-footer{display:flex;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--app-border)}.meter-card-date{font-size:10px;color:var(--app-text-muted)}.meter-selection-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--app-accent-bg);border:1px solid var(--app-accent);border-radius:8px;margin-bottom:1rem}.meter-selection-actions-count{font-size:.875rem;font-weight:500;color:var(--app-accent)}.meter-selection-actions-buttons{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.meter-selection-actions-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:background-color .15s,color .15s,box-shadow .15s;font-family:inherit;border:none}.meter-selection-actions-btn:disabled{opacity:.5;cursor:not-allowed}.meter-selection-actions-btn-primary{background:var(--app-accent);color:#fff}.meter-selection-actions-btn-primary:hover:not(:disabled){background:var(--app-accent-hover);box-shadow:0 2px 4px var(--app-accent-bg)}.meter-selection-actions-btn-secondary{background:var(--app-surface);color:var(--app-text);border:1px solid var(--app-border)}.meter-selection-actions-btn-secondary:hover:not(:disabled){background:var(--app-bg);border-color:var(--app-text-muted)}.meter-selection-actions-btn-text{background:transparent;color:var(--app-text-muted)}.meter-selection-actions-btn-text:hover{color:var(--app-text);text-decoration:underline}.devices-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.devices-page-loading,.devices-page-error,.devices-page-empty{padding:16px 24px;color:var(--app-text-muted)}.devices-page-error{color:#b91c1c}.settings-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.settings-content{flex:1;padding:24px;width:100%;max-width:none;margin:0 auto;display:flex;gap:16px;align-items:flex-start}.settings-tabs{width:220px;display:flex;flex-direction:column;gap:8px;position:sticky;top:24px}.settings-tab-btn{width:100%;text-align:left;padding:10px 14px;border-radius:8px;border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text);cursor:pointer;transition:border-color .15s ease,background .15s ease}.settings-tab-btn:hover{border-color:var(--app-accent);background:var(--app-accent-bg)}.settings-tab-btn--active{border-color:var(--app-accent);background:var(--app-accent-bg);color:var(--app-accent)}.settings-section{flex:1;margin:0;padding:24px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:8px}.settings-section-title{margin:0 0 20px;font-size:1.125rem;font-weight:600;color:var(--app-text)}.settings-group{margin-bottom:24px}.settings-group:last-child{margin-bottom:0}.settings-label{display:block;margin-bottom:10px;font-weight:600;font-size:.9375rem;color:var(--app-text)}.settings-options{display:flex;flex-wrap:wrap;gap:10px}.settings-option-btn{padding:10px 18px;font-size:.9375rem;font-weight:500;color:var(--app-text);background:var(--app-bg);border:1px solid var(--app-border);border-radius:8px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.settings-option-btn:hover{border-color:var(--app-accent);background:var(--app-accent-bg)}.settings-option-btn--active{border-color:var(--app-accent);background:var(--app-accent-bg);color:var(--app-accent)}.settings-hint{margin:8px 0 16px;font-size:.8125rem;line-height:1.5;color:var(--app-text-muted)}.settings-checkbox-row{display:flex;align-items:center;gap:10px}.settings-checkbox{width:16px;height:16px;margin:0;accent-color:var(--app-accent)}.settings-checkbox-label{font-weight:600;color:var(--app-text);cursor:pointer}.settings-place-form{margin-bottom:20px}.settings-place-actions,.settings-customization-toolbar{margin-bottom:16px}.settings-dialog-wide{max-width:720px}.settings-dialog--rich{box-shadow:0 0 0 1px color-mix(in srgb,var(--app-text) 4%,transparent),0 24px 48px -12px var(--app-shadow, rgba(0, 0, 0, .18))}.settings-dialog-wide.settings-dialog--rich{max-width:min(960px,calc(100vw - 40px));width:100%}.settings-dialog-wide.settings-dialog--rich.settings-dialog-rule{max-width:900px}.settings-dialog-header--rich{align-items:flex-start;gap:8px 16px;padding:20px 22px 18px;background:color-mix(in srgb,var(--app-accent) 6%,var(--app-surface));border-bottom:1px solid var(--app-border)}.settings-dialog-lead{display:flex;align-items:flex-start;gap:14px;min-width:0;flex:1;padding-top:2px}.settings-dialog-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--app-accent-bg);color:var(--app-accent);border:1px solid color-mix(in srgb,var(--app-accent) 22%,transparent)}.settings-dialog-lead-text{min-width:0}.settings-dialog-title--hero{margin:0;font-size:1.25rem;font-weight:600;line-height:1.25;color:var(--app-text)}.settings-dialog-subtitle{margin:4px 0 0;max-width:36rem;font-size:.875rem;line-height:1.45;color:var(--app-text-muted);font-weight:400}.settings-dialog-content--padded{padding:20px 24px 16px}.settings-dialog-content--scrollable{max-height:min(70vh,800px);overflow-y:auto}.settings-form-section{margin:0 0 24px}.settings-form-section:last-of-type{margin-bottom:0}.settings-form-section-label{margin:0 0 12px;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--app-text-muted)}.settings-form-hint-inline{margin:0 0 12px;font-size:.75rem;line-height:1.4;color:var(--app-text-muted)}.settings-error-box{margin:0 0 16px;padding:10px 12px;border-radius:8px;border:1px solid rgba(239,68,68,.35);background:#ef444414;font-size:.875rem}.settings-dialog-btn-ghost{border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text)}.settings-pending-fields-section{margin-top:8px}.settings-pending-fields-label{margin-bottom:10px}.settings-pending-fields-list{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.settings-pending-field-block{width:100%}.settings-pending-field-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px}.settings-pending-field-grow{flex:1 1 200px;min-width:0}.settings-pending-field-type{flex:0 1 220px;min-width:0}.settings-pending-field-remove{height:38px;padding:0 12px;border-radius:8px;border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text-muted);cursor:pointer;font-family:inherit;align-self:flex-end}.settings-pending-field-remove:hover:not(:disabled){border-color:#d04646;color:#d04646}.settings-pending-field-remove:disabled{opacity:.65;cursor:default}.settings-add-pending-field-btn{margin-top:0}.settings-place-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.settings-floating-field{min-width:0}.settings-input{width:100%;height:38px;border-radius:8px;border:1px solid var(--app-input-border);background-color:var(--app-input-bg);color:var(--app-input-text);padding:0 10px}.floating-field-input.settings-input,.floating-field-select-control.settings-input{height:auto}.floating-field-input.settings-input{min-height:38px;padding:8px 10px;line-height:1.25}.floating-field-select-control.settings-input{min-height:38px;padding:10px 10px 5px;line-height:1.25}.settings-submit-btn{height:36px;border:1px solid var(--app-accent);border-radius:8px;padding:0 14px;background:var(--app-accent-bg);color:var(--app-accent);cursor:pointer}.settings-submit-btn:disabled{opacity:.7;cursor:default}.settings-error{margin:12px 0;color:#d04646;font-weight:500}.settings-places-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.settings-place-item{border:1px solid var(--app-border);border-radius:8px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.settings-place-item--tree{flex-direction:column;align-items:stretch}.settings-place-item-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%}.settings-place-add-child-btn{padding:6px 10px;font-size:.8125rem;font-weight:600;color:var(--app-primary, #2563eb);background:transparent;border:1px solid var(--app-primary, #2563eb);border-radius:6px;cursor:pointer}.settings-place-add-child-btn:hover:not(:disabled){background:color-mix(in srgb,var(--app-primary, #2563eb) 12%,transparent)}.settings-place-add-child-btn:disabled{opacity:.5;cursor:not-allowed}.settings-place-type-readonly{grid-column:1 / -1;padding:12px 14px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface-muted, rgba(0, 0, 0, .04));display:flex;flex-direction:column;gap:4px}.settings-place-type-readonly-label{font-size:.75rem;font-weight:600;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.04em}.settings-place-type-readonly-value{font-size:1rem;font-weight:600;color:var(--app-text)}.settings-place-type-readonly-hint{font-size:.8125rem;color:var(--app-text-muted)}.settings-places-nested{list-style:none;margin:8px 0 0;padding:0 0 0 12px;display:flex;flex-direction:column;gap:8px;border-left:1px solid var(--app-border)}.settings-place-row-head{display:flex;align-items:flex-start;gap:6px;flex:1;min-width:0}.settings-place-expand{flex-shrink:0;width:28px;height:28px;margin-top:2px;padding:0;border:none;background:transparent;color:var(--app-text-muted);cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;justify-content:center}.settings-place-expand:hover{color:var(--app-text);background:var(--app-surface-hover, rgba(0, 0, 0, .06))}.settings-place-expand-spacer{width:28px;flex-shrink:0}.settings-place-expand-icon{display:inline-block;transition:transform .15s ease}.settings-place-expand-icon-expanded{transform:rotate(90deg)}.settings-place-main{display:flex;flex-direction:column;min-width:0}.settings-place-meta{color:var(--app-text-muted);font-size:.85rem}.settings-meter-types-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.settings-meter-type-item{border:1px solid var(--app-border);border-radius:8px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.settings-meter-type-main{display:flex;flex-direction:column;min-width:0}.settings-meter-type-meta{color:var(--app-text-muted);font-size:.85rem}.settings-meter-type-checkboxes{display:flex;flex-wrap:wrap;gap:10px 16px;margin-top:6px}.settings-meter-type-checkbox{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;color:var(--app-text)}.settings-meter-type-limits-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--app-border)}.settings-meter-type-limits-title{margin:0 0 12px;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--app-text-muted)}.settings-meter-type-limits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 12px;margin-top:8px}.settings-meter-type-limits-label{display:block;font-size:.75rem;font-weight:600;color:var(--app-text-muted);margin-bottom:6px}.settings-meter-type-limits-pair-inputs,.settings-meter-type-limits-triple-inputs{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}.settings-meter-type-limits-pair-inputs .floating-field,.settings-meter-type-limits-triple-inputs .floating-field{flex:1 1 120px;min-width:0}.settings-meter-type-limits-triple-inputs .floating-field{flex:1 1 100px}.settings-delete-btn{border:1px solid #d04646;background:transparent;color:#d04646;border-radius:8px;height:32px;padding:0 10px;cursor:pointer}.settings-edit-btn{border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text);border-radius:8px;height:32px;padding:0 10px;cursor:pointer}.settings-place-actions-inline{display:flex;align-items:center;gap:8px}.settings-delete-btn:disabled{opacity:.65;cursor:default}.settings-edit-btn:disabled{opacity:.65;cursor:default}.settings-empty{color:var(--app-text-muted);border:1px dashed var(--app-border);border-radius:8px;padding:12px}.settings-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.settings-dialog{width:100%;max-width:620px;background:var(--app-surface);border:1px solid var(--app-border);border-radius:12px;box-shadow:0 20px 25px -5px var(--app-shadow);overflow:hidden}.settings-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--app-border)}.settings-dialog-title{margin:0;color:var(--app-text);font-size:1.05rem}.settings-dialog-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;border:none;background:transparent;color:var(--app-text-muted);font-size:1.4rem;line-height:1;cursor:pointer;border-radius:6px;width:32px;height:32px;padding:0}.settings-dialog-close:hover:not(:disabled){background:var(--app-bg);color:var(--app-text)}.settings-dialog-content{padding:16px 20px 6px}.settings-dialog-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px 18px;border-top:1px solid var(--app-border);background-color:var(--app-input-bg)}.settings-dialog-btn{height:36px;border-radius:8px;padding:0 14px;font-family:inherit;cursor:pointer}.settings-dialog-btn-cancel{border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text-muted)}.settings-dialog-btn-confirm{border:1px solid var(--app-accent);background:var(--app-accent-bg);color:var(--app-accent)}.settings-dialog-btn:disabled,.settings-dialog-close:disabled{opacity:.7;cursor:default}.settings-customization-layout{margin-top:8px}.settings-customization-empty-full{margin-top:0}.settings-customization-two-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}.settings-customization-column{display:flex;flex-direction:column;gap:14px;min-width:0}.settings-customization-column-title{margin:0;padding-bottom:8px;font-size:1rem;font-weight:600;color:var(--app-text);border-bottom:1px solid var(--app-border)}.settings-customization-column-body{display:flex;flex-direction:column;gap:16px}.settings-custom-type-block{border:1px solid var(--app-border);border-radius:8px;padding:14px 16px;background:var(--app-bg)}.settings-custom-type-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.settings-custom-type-heading{min-width:0;flex:1}.settings-custom-type-header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-shrink:0;flex-wrap:wrap}.settings-custom-add-field-btn,.settings-custom-delete-type-btn,.settings-custom-edit-type-btn{flex-shrink:0;white-space:nowrap}.settings-custom-type-title{margin:0 0 4px;font-size:1rem;font-weight:600;color:var(--app-text)}.settings-custom-type-meta{margin:0;font-size:.8125rem;color:var(--app-text-muted);font-family:ui-monospace,monospace}.settings-custom-dialog-device{margin:0 0 14px;font-size:.9375rem;color:var(--app-text)}.settings-custom-dialog-device-code{color:var(--app-text-muted);font-size:.8125rem;font-family:ui-monospace,monospace}.settings-custom-dialog-device-id{margin:0 0 14px;font-size:.8125rem;color:var(--app-text-muted);font-family:ui-monospace,monospace}.settings-custom-fields-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.settings-custom-field-item{border:1px solid var(--app-border);border-radius:8px;padding:10px 12px;background:var(--app-surface);display:flex;align-items:center;justify-content:space-between;gap:10px}.settings-custom-field-main{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.settings-custom-field-actions{flex-shrink:0}.settings-custom-field-meta{font-size:.85rem;color:var(--app-text-muted);word-break:break-all}.settings-custom-field-options-preview{list-style:none;margin:6px 0 0;padding:0 0 0 14px;font-size:.8125rem;color:var(--app-text-muted);display:flex;flex-direction:column;gap:2px}.settings-custom-field-options-preview li{position:relative}.settings-custom-field-options-preview li:before{content:"·";position:absolute;left:-10px;color:var(--app-text-muted)}.settings-custom-field-dialog-options{margin-top:8px;padding-top:12px;border-top:1px solid var(--app-border)}.settings-custom-field-dialog-options-label{margin:0 0 6px}.settings-custom-field-dialog-options-hint{margin:0 0 10px;font-size:.8125rem}.settings-custom-empty{margin:0;border-color:color-mix(in srgb,var(--app-text-muted) 55%,var(--app-border) 45%)}.settings-rules-intro{margin:0 0 16px;max-width:720px;line-height:1.5}.settings-rule-message{display:block;margin-top:8px;font-size:.875rem;color:var(--app-text-muted)}.settings-rule-message-field{margin-top:16px;margin-bottom:0}.settings-rule-message-field .settings-label{margin-bottom:12px}.settings-rule-message-textarea{margin-top:8px;min-height:72px;height:auto;padding:10px;resize:vertical;font-family:inherit;line-height:1.4;box-sizing:border-box}.settings-rule-constraint-row{display:flex;flex-wrap:wrap;gap:16px 18px;align-items:flex-end;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--app-border)}.settings-rule-constraint-row>*:not(.settings-rules-constraint-actions){flex:1 1 188px;min-width:160px;max-width:100%}.settings-rule-constraint-row:last-of-type{border-bottom:none;margin-bottom:8px;padding-bottom:0}.settings-rules-constraint-actions{display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-left:auto;align-self:flex-end;min-height:38px}.settings-rule-constraint-remove{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;margin:0;border:none;border-radius:6px;background:transparent;color:#d04646;cursor:pointer;flex-shrink:0}.settings-rule-constraint-remove:hover:not(:disabled){background:color-mix(in srgb,#d04646 14%,transparent);color:#b83838}.settings-rule-constraint-remove:focus-visible{outline:2px solid color-mix(in srgb,#d04646 45%,transparent);outline-offset:2px}.settings-rule-constraint-remove:disabled{opacity:.35;cursor:not-allowed}@media(max-width:900px){.settings-customization-two-columns{grid-template-columns:1fr}}@media(max-width:860px){.settings-content{flex-direction:column}.settings-tabs{width:100%;position:static;flex-direction:row;flex-wrap:wrap}}.add-from-range-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.add-from-range-content{flex:1;padding:28px 24px;max-width:800px;margin:0 auto;width:100%}.add-from-range-form{display:flex;flex-direction:column;gap:28px}.add-from-range-summary-card{background:var(--app-accent-bg);border:2px solid var(--app-accent);border-radius:12px;padding:16px 18px;box-shadow:0 0 0 1px var(--app-accent-bg),0 1px 3px var(--app-shadow)}.add-from-range-summary-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.add-from-range-summary-header h3{margin:0;font-size:14px;font-weight:700;color:var(--app-text)}.add-from-range-summary-step{font-size:12px;font-weight:700;color:#fff;background:var(--app-accent);border:1px solid var(--app-accent);border-radius:999px;padding:4px 10px}.add-from-range-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.add-from-range-summary-item{display:flex;flex-direction:column;gap:6px;min-width:0}.add-from-range-summary-label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--app-text)}.add-from-range-summary-value{display:inline-block;width:-moz-fit-content;width:fit-content;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:4px 8px;border:1px solid var(--app-accent);border-radius:6px;background:var(--app-surface);color:var(--app-text);font-size:12px;font-weight:600}.add-from-range-summary-text{font-size:14px;font-weight:600;color:var(--app-text)}.add-from-range-step{background:var(--app-surface);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid var(--app-border)}.add-from-range-step-actions{display:flex;justify-content:flex-end;margin-top:18px}.add-from-range-step-continue{padding:10px 20px;border:1px solid var(--app-accent);border-radius:8px;background:var(--app-accent-bg);color:var(--app-accent);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-from-range-step-continue:hover:not(:disabled){background:var(--app-accent-bg);border-color:var(--app-accent-hover);color:var(--app-accent)}.add-from-range-step-continue:disabled{opacity:.5;cursor:not-allowed}.add-from-range-step-title{display:flex;align-items:center;gap:12px;margin:0 0 8px;font-size:16px;font-weight:600;color:var(--app-text)}.add-from-range-step-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.add-from-range-step-header .add-from-range-step-title{margin-bottom:0}.add-from-range-step-back{width:32px;height:32px;border-radius:999px;border:1px solid var(--app-border);background:var(--app-surface);color:var(--app-text-muted);font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.add-from-range-step-back:hover{border-color:var(--app-text-muted);background:var(--app-bg)}.add-from-range-step-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--app-accent);color:#fff;font-size:14px;font-weight:600}.add-from-range-step-desc{margin:0 0 20px 40px;font-size:14px;color:var(--app-text-muted);line-height:1.5}.add-from-range-pattern-builder{display:flex;align-items:flex-end;gap:12px;flex-wrap:nowrap;margin-left:40px}.add-from-range-pattern-part{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.add-from-range-pattern-part label{font-size:12px;font-weight:500;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.add-from-range-pattern-input{padding:12px 16px;border:1px solid var(--app-input-border);border-radius:8px;font-size:15px;font-family:ui-monospace,monospace;width:100%;box-sizing:border-box;background-color:var(--app-input-bg);color:var(--app-input-text);transition:border-color .15s,box-shadow .15s}.add-from-range-pattern-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-alpha-15)}.add-from-range-pattern-input::-moz-placeholder{color:var(--app-text-muted)}.add-from-range-pattern-input::placeholder{color:var(--app-text-muted)}.add-from-range-pattern-plus{flex-shrink:0}.add-from-range-pattern-plus{font-size:18px;font-weight:300;color:var(--app-text-muted);padding-bottom:12px;flex-shrink:0}.add-from-range-live-preview{display:flex;align-items:center;gap:10px;margin-top:16px;margin-left:40px;padding:12px 16px;background:var(--app-accent-bg);border:1px solid var(--app-border);border-radius:8px;font-size:14px}.add-from-range-live-label{color:#0369a1;font-weight:500}.add-from-range-live-value{padding:2px 8px;background:var(--app-surface);border-radius:4px;font-family:ui-monospace,monospace;font-size:13px;color:var(--app-text);border:1px solid var(--app-border)}.add-from-range-live-arrow{color:var(--app-text-muted);font-weight:500}.add-from-range-quantity{margin-left:40px;display:flex;flex-direction:column;align-items:center}.add-from-range-quantity-input-wrap{display:flex;align-items:center;gap:12px;margin-bottom:14px;width:-moz-fit-content;width:fit-content;padding:8px 4px 10px 0;border-bottom:2px solid var(--app-border);transition:border-color .2s ease}.add-from-range-quantity-input{width:180px;padding:2px 0;border:none;border-radius:0;background:transparent;font-size:34px;font-weight:700;line-height:1.1;text-align:center;letter-spacing:.01em;color:var(--app-text);-moz-appearance:textfield}.add-from-range-quantity-input:focus{outline:none;border-color:transparent;box-shadow:none}.add-from-range-quantity-input::-webkit-outer-spin-button,.add-from-range-quantity-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.add-from-range-quantity-input-wrap:focus-within{border-bottom-color:var(--app-accent)}.add-from-range-count-buttons{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.add-from-range-count-btn{padding:8px 16px;font-size:13px;font-weight:500;color:var(--app-text-muted);background:var(--app-bg);border:1px solid var(--app-border);border-radius:8px;cursor:pointer;transition:all .15s ease}.add-from-range-count-btn:hover{border-color:var(--app-accent);color:var(--app-accent);background:var(--app-accent-bg)}.add-from-range-count-btn.active{border-color:var(--app-accent);background:var(--app-accent);color:#fff}.add-from-range-count-btn.active:hover{background:var(--app-accent-hover);border-color:var(--app-accent-hover)}.add-from-range-preview-actions{display:flex;gap:12px;margin-bottom:0}.add-from-range-confirm{padding:12px 24px;border:none;border-radius:8px;background:#10b981;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-from-range-confirm:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.add-from-range-confirm:disabled{opacity:.5;cursor:not-allowed;transform:none}.add-from-range-reset{padding:12px 24px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface);color:var(--app-text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-from-range-reset:hover:not(:disabled){border-color:var(--app-border);background:var(--app-bg);color:var(--app-text-muted)}.add-from-range-reset:disabled{opacity:.5;cursor:not-allowed}.add-from-range-preview{margin-top:20px;padding:20px;background:var(--app-bg);border-radius:10px;border:1px solid var(--app-border)}.add-from-range-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.add-from-range-preview-header h3{margin:0;font-size:14px;font-weight:600;color:var(--app-text)}.add-from-range-preview-count{font-size:13px;color:var(--app-text-muted);font-weight:500}.add-from-range-preview-summary{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;background:var(--app-surface);border-radius:6px;border:1px solid var(--app-border);font-size:14px}.add-from-range-preview-summary code{font-family:ui-monospace,monospace;padding:2px 6px;background:var(--app-bg);border-radius:4px;font-size:13px}.add-from-range-preview-ellipsis{color:var(--app-text-muted);font-weight:500}.add-from-range-preview-list{max-height:220px;overflow-y:auto;font-size:13px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface)}.add-from-range-preview-item{padding:8px 14px;border-bottom:1px solid var(--app-bg);font-family:ui-monospace,monospace;color:var(--app-text-muted)}.add-from-range-preview-item:last-child{border-bottom:none}.add-from-range-error{padding:14px 18px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;line-height:1.5}.add-from-range-actions{display:flex;justify-content:flex-end;padding-top:8px}.add-from-range-submit{padding:14px 32px;border:none;border-radius:10px;background:var(--app-accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-from-range-submit:hover:not(:disabled){background:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--app-accent-alpha-35)}.add-from-range-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}@media(max-width:520px){.add-from-range-pattern-builder{flex-direction:column;align-items:stretch;margin-left:0}.add-from-range-pattern-plus{display:none}.add-from-range-step-desc{margin-left:0}.add-from-range-live-preview{margin-left:0;flex-wrap:wrap}.add-from-range-quantity{margin-left:0}}@media(max-width:640px){.add-from-range-summary-grid{grid-template-columns:1fr}.add-from-range-summary-header{align-items:flex-start;flex-direction:column}.add-from-range-step-desc,.add-from-range-live-preview,.add-from-range-quantity,.add-from-range-pattern-builder{margin-left:0}}.add-meter-type-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:add-meter-type-dialog-fadeIn .2s ease-out}@keyframes add-meter-type-dialog-fadeIn{0%{opacity:0}to{opacity:1}}.add-meter-type-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:720px;max-height:90vh;width:100%;display:flex;flex-direction:column;animation:add-meter-type-dialog-slideUp .3s ease-out;overflow:hidden}@keyframes add-meter-type-dialog-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.add-meter-type-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.add-meter-type-dialog-title{margin:0;font-size:20px;font-weight:600;color:#1f2937}.add-meter-type-dialog-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.add-meter-type-dialog-close:hover{background-color:var(--app-bg);color:#1f2937}.add-meter-type-dialog-form{display:flex;flex-direction:column;flex:1;min-height:0}.add-meter-type-dialog-content{padding:24px;overflow-y:auto;flex:1}.add-meter-type-dialog-section{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid #e5e7eb}.add-meter-type-dialog-section:last-child{border-bottom:none;margin-bottom:0}.add-meter-type-dialog-section h3{margin:0 0 12px;font-size:15px;font-weight:600;color:#374151}.add-meter-type-dialog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.add-meter-type-dialog-grid-limits{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.add-meter-type-dialog-field{display:flex;flex-direction:column;gap:4px}.add-meter-type-dialog-field.add-meter-type-dialog-span-2{grid-column:span 2}.add-meter-type-dialog-field label{font-size:13px;font-weight:500;color:#374151}.add-meter-type-dialog-field input{padding:8px 12px;border:1px solid var(--app-input-border);border-radius:6px;font-size:14px;font-family:inherit;background-color:var(--app-input-bg);color:var(--app-input-text)}.add-meter-type-dialog-field input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent-alpha-15)}.add-meter-type-dialog-checkbox label{display:flex;align-items:center;gap:8px;cursor:pointer}.add-meter-type-dialog-checkbox input[type=checkbox]{width:18px;height:18px}.add-meter-type-dialog-autocomplete{position:relative;margin-bottom:12px}.add-meter-type-dialog-autocomplete-list{position:absolute;top:100%;left:0;right:0;margin:4px 0 0;padding:0;list-style:none;background:var(--app-surface);border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;max-height:200px;overflow-y:auto;z-index:10}.add-meter-type-dialog-autocomplete-item{padding:10px 12px;cursor:pointer;font-size:14px;border-bottom:1px solid var(--app-bg)}.add-meter-type-dialog-autocomplete-item:last-child{border-bottom:none}.add-meter-type-dialog-autocomplete-item:hover{background-color:var(--app-bg)}.add-meter-type-dialog-readonly{background-color:var(--app-surface);color:#6b7280;cursor:default}.add-meter-type-dialog-pair,.add-meter-type-dialog-triple{display:flex;gap:8px}.add-meter-type-dialog-pair input,.add-meter-type-dialog-triple input{flex:1;min-width:0}.add-meter-type-dialog-error{padding:12px 24px;margin:0 24px;background-color:#fef2f2;color:#b91c1c;border-radius:8px;font-size:14px}.add-meter-type-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;flex-shrink:0;background-color:var(--app-input-bg)}.add-meter-type-dialog-btn{padding:10px 20px;font-size:14px;font-weight:500;border-radius:8px;cursor:pointer;font-family:inherit;border:none}.add-meter-type-dialog-btn-cancel{background:var(--app-surface);color:#374151;border:1px solid #d1d5db}.add-meter-type-dialog-btn-cancel:hover{background:var(--app-surface);border-color:#9ca3af}.add-meter-type-dialog-btn-save{background:var(--app-accent);color:#fff}.add-meter-type-dialog-btn-save:hover{background:var(--app-accent-hover);box-shadow:0 2px 4px var(--app-accent-alpha-30)}.add-meter-type-dialog-btn-save:disabled,.add-meter-type-dialog-btn-cancel:disabled{opacity:.6;cursor:not-allowed}@media(prefers-color-scheme:dark){.add-meter-type-dialog{background:#1f2937}.add-meter-type-dialog-header{border-bottom-color:#4b5563}.add-meter-type-dialog-title{color:var(--app-surface)}.add-meter-type-dialog-close{color:#9ca3af}.add-meter-type-dialog-close:hover{background:#374151;color:var(--app-surface)}.add-meter-type-dialog-section{border-bottom-color:#4b5563}.add-meter-type-dialog-section h3,.add-meter-type-dialog-field label{color:#e5e7eb}.add-meter-type-dialog-field input{background:#111827;border-color:#4b5563;color:var(--app-surface)}.add-meter-type-dialog-autocomplete-list{background:#1f2937;border-color:#4b5563}.add-meter-type-dialog-autocomplete-item{border-bottom-color:#374151}.add-meter-type-dialog-autocomplete-item:hover{background-color:#374151}.add-meter-type-dialog-readonly{background-color:#111827;color:#9ca3af}.add-meter-type-dialog-error{background-color:#7f1d1d;color:#fca5a5}.add-meter-type-dialog-footer{border-top-color:#4b5563;background-color:var(--app-input-bg)}.add-meter-type-dialog-btn-cancel{background:#374151;color:#e5e7eb;border-color:#4b5563}.add-meter-type-dialog-btn-cancel:hover{background:#4b5563}}.add-from-range-details-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.add-from-range-details-content{flex:1;padding:28px 24px;max-width:1000px;margin:0 auto;width:100%}.add-from-range-details-form{display:flex;flex-direction:column;gap:24px}.add-from-range-details-intro{padding:16px 20px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;font-size:14px;color:#0369a1;line-height:1.5}.add-from-range-details-intro p{margin:0}.add-from-range-details-main{display:flex;gap:24px;min-height:420px}.add-from-range-details-step-card{background:var(--app-surface);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden}.add-from-range-details-step-title{display:flex;align-items:center;gap:12px;margin:0 0 20px;font-size:16px;font-weight:600;color:#0f172a}.add-from-range-details-step-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--app-accent);color:#fff;font-size:14px;font-weight:600}.add-from-range-details-list-card{flex:0 0 280px}.add-from-range-details-add-btn{width:100%;padding:12px 16px;font-size:14px;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:16px}.add-from-range-details-add-btn:hover{background:#059669;transform:translateY(-1px)}.add-from-range-details-meter-type-list{flex:1;display:flex;flex-direction:column;min-height:0}.add-from-range-details-meter-type-list ul{margin:0;padding:0;list-style:none;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:6px}.add-from-range-details-meter-type-list li{margin:0}.add-from-range-details-list-item{display:block;width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#334155;font-size:14px;font-weight:500;text-align:left;cursor:pointer;transition:all .15s ease}.add-from-range-details-list-item:hover{border-color:var(--app-accent);background:#eff6ff;color:var(--app-accent)}.add-from-range-details-list-item.selected{border-color:var(--app-accent);background:var(--app-accent);color:#fff}.add-from-range-details-list-item.selected:hover{background:var(--app-accent-hover);border-color:var(--app-accent-hover)}.add-from-range-details-list-loading,.add-from-range-details-list-empty{margin:24px 0;color:#64748b;font-size:14px;text-align:center}.add-from-range-details-info-card{flex:1;min-width:0}.add-from-range-details-info-panel{flex:1;min-height:0;overflow-y:auto}.add-from-range-details-info-placeholder{display:flex;align-items:center;justify-content:center;min-height:280px;padding:24px}.add-from-range-details-info-placeholder p{margin:0;color:#94a3b8;font-size:14px;text-align:center;max-width:260px}.add-from-range-details-info-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;min-height:280px;padding:24px}.add-from-range-details-info-empty-text{margin:0;color:#64748b;font-size:14px;text-align:center}.add-from-range-details-add-btn-center{padding:14px 28px;font-size:15px;font-weight:600;color:#fff;background:var(--app-accent);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.add-from-range-details-add-btn-center:hover{background:var(--app-accent-hover);transform:translateY(-1px)}.add-from-range-details-info-content{padding:4px 0 0}.add-from-range-details-info-content h4{margin:20px 0 10px;font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.add-from-range-details-info-content h4:first-child{margin-top:0}.add-from-range-details-info-block{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px 24px}.add-from-range-details-info-limits{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.add-from-range-details-info-row{display:flex;flex-direction:column;gap:2px}.add-from-range-details-info-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.add-from-range-details-info-value{font-size:14px;font-weight:500;color:#0f172a}.add-from-range-details-error{padding:14px 18px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;line-height:1.5}.add-from-range-details-actions{display:flex;justify-content:flex-end;padding-top:8px}.add-from-range-details-submit{padding:14px 32px;border:none;border-radius:10px;background:var(--app-accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-from-range-details-submit:hover:not(:disabled){background:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--app-accent-alpha-35)}.add-from-range-details-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}@media(max-width:768px){.add-from-range-details-main{flex-direction:column;min-height:auto}.add-from-range-details-list-card{flex:0 0 auto;max-height:240px}.add-from-range-details-meter-type-list ul{max-height:160px}}@media(prefers-color-scheme:dark){.add-from-range-details-page{background:var(--app-bg)}.add-from-range-details-intro{background:#0f172a;border-color:#1e3a8a;color:#7dd3fc}.add-from-range-details-step-card{background:#1e293b;border-color:#334155}.add-from-range-details-step-title{color:#f8fafc}.add-from-range-details-add-btn{background:#059669}.add-from-range-details-add-btn:hover{background:#047857}.add-from-range-details-list-item{background:#0f172a;border-color:#334155;color:#e2e8f0}.add-from-range-details-list-item:hover{border-color:var(--app-accent);background:#1e3a8a;color:var(--app-accent)}.add-from-range-details-list-item.selected{background:var(--app-accent);color:#fff;border-color:var(--app-accent)}.add-from-range-details-list-item.selected:hover{background:var(--app-accent-hover);border-color:var(--app-accent-hover)}.add-from-range-details-list-loading,.add-from-range-details-list-empty{color:#94a3b8}.add-from-range-details-info-placeholder p{color:#64748b}.add-from-range-details-info-empty-text,.add-from-range-details-info-content h4{color:#94a3b8}.add-from-range-details-info-label{color:#64748b}.add-from-range-details-info-value{color:#f8fafc}}.add-from-file-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.add-from-file-content{flex:1;padding:28px 24px;max-width:800px;margin:0 auto;width:100%}.add-from-file-step{background:var(--app-surface);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid var(--app-border)}.add-from-file-step-title{display:flex;align-items:center;gap:12px;margin:0 0 8px;font-size:16px;font-weight:600;color:var(--app-text)}.add-from-file-step-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--app-accent);color:#fff;font-size:14px;font-weight:600}.add-from-file-step-desc{margin:0 0 20px;font-size:14px;color:var(--app-text-muted);line-height:1.5}.add-from-file-file-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}.add-from-file-file-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.add-from-file-browse-btn{padding:12px 24px;border:1px solid var(--app-border);border-radius:8px;background:var(--app-surface);color:var(--app-text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.add-from-file-browse-btn:hover{border-color:var(--app-accent);color:var(--app-accent);background:var(--app-accent-bg)}.add-from-file-filename{font-size:14px;color:var(--app-text-muted);max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-from-file-error{padding:14px 18px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;line-height:1.5;margin-bottom:20px}.add-from-file-actions{display:flex;justify-content:flex-end;padding-top:8px}.add-from-file-actions-row{gap:12px}.add-from-file-submit{padding:14px 32px;border:none;border-radius:10px;background:var(--app-accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-from-file-submit:hover:not(:disabled){background:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--app-accent-alpha-35)}.add-from-file-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.add-from-file-secondary{padding:14px 24px;border:1px solid var(--app-border);border-radius:10px;background:var(--app-surface);color:var(--app-text-muted);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-from-file-secondary:hover:not(:disabled){border-color:var(--app-border);background:var(--app-bg);color:var(--app-text-muted)}.add-from-file-secondary:disabled{opacity:.5;cursor:not-allowed}.add-from-file-step-validating{min-height:180px;display:flex;flex-direction:column}.add-from-file-validating{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px}.add-from-file-validating p{margin:0;font-size:14px;color:var(--app-text-muted)}.add-from-file-spinner{width:36px;height:36px;border:3px solid var(--app-border);border-top-color:var(--app-accent);border-radius:50%;animation:add-from-file-spin .8s linear infinite}@keyframes add-from-file-spin{to{transform:rotate(360deg)}}.add-from-file-info{margin-bottom:24px}.add-from-file-info-list{display:grid;gap:12px 24px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin:0 0 20px}.add-from-file-info-list div{display:flex;flex-direction:column;gap:4px}.add-from-file-info-list dt{margin:0;font-size:12px;font-weight:500;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.add-from-file-info-list dd{margin:0;font-size:15px;font-weight:500;color:var(--app-text)}.add-from-file-preview{padding:16px;background:var(--app-bg);border-radius:8px;border:1px solid var(--app-border)}.add-from-file-preview h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--app-text)}.add-from-file-preview-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.add-from-file-preview-summary code{font-family:ui-monospace,monospace;padding:4px 10px;background:var(--app-surface);border-radius:6px;font-size:13px;border:1px solid var(--app-border)}.add-from-file-preview-ellipsis{color:var(--app-text-muted);font-weight:500}.add-from-file-confirm-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.add-from-file-confirm-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:440px;width:100%;display:flex;flex-direction:column;overflow:hidden}.add-from-file-confirm-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border)}.add-from-file-confirm-title{margin:0;font-size:18px;font-weight:600;color:var(--app-text)}.add-from-file-confirm-close{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:20px;line-height:1;color:var(--app-text-muted);border-radius:6px;transition:background .2s ease,color .2s ease}.add-from-file-confirm-close:hover{background:var(--app-bg);color:var(--app-text)}.add-from-file-confirm-content{padding:24px;display:flex;flex-direction:column;gap:16px}.add-from-file-confirm-summary{margin:0;font-size:14px;font-weight:600;color:var(--app-text-muted)}.add-from-file-confirm-info{display:grid;gap:8px 20px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin:0}.add-from-file-confirm-info div{display:flex;flex-direction:column;gap:2px}.add-from-file-confirm-info dt{margin:0;font-size:12px;font-weight:500;color:var(--app-text-muted);text-transform:uppercase;letter-spacing:.05em}.add-from-file-confirm-info dd{margin:0;font-size:14px;font-weight:500;color:var(--app-text)}.add-from-file-confirm-received{padding-top:12px;border-top:1px solid var(--app-border)}.add-from-file-confirm-received-label{display:block;font-size:14px;font-weight:600;color:var(--app-text-muted);margin-bottom:10px}.add-from-file-confirm-received-options{display:flex;gap:20px;flex-wrap:wrap}.add-from-file-confirm-received-option{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--app-text-muted)}.add-from-file-confirm-received-option input{margin:0;cursor:pointer}.add-from-file-confirm-place{margin-top:8px}.add-from-file-confirm-place-label{display:block;font-size:14px;font-weight:600;color:var(--app-text-muted);margin-bottom:8px}.add-from-file-confirm-place-select{width:100%;max-width:320px;padding:10px 12px;font-size:14px;font-family:inherit;border:1px solid var(--app-input-border);border-radius:8px;background-color:var(--app-input-bg);color:var(--app-input-text)}.add-from-file-confirm-place-loading{font-size:14px;color:var(--app-text-muted);margin:0}.add-from-file-confirm-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--app-border);background-color:var(--app-input-bg)}.add-from-file-confirm-btn{padding:10px 20px;font-size:14px;font-weight:600;font-family:inherit;border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.add-from-file-confirm-btn-cancel{background:var(--app-surface);border:1px solid var(--app-border);color:var(--app-text-muted)}.add-from-file-confirm-btn-cancel:hover{background:var(--app-bg);border-color:var(--app-border)}.add-from-file-confirm-btn-confirm{background:var(--app-accent);border:none;color:#fff}.add-from-file-confirm-btn-confirm:hover:not(:disabled){background:var(--app-accent-hover)}.add-from-file-confirm-btn-confirm:disabled{cursor:not-allowed;opacity:.7}.add-by-hand-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.add-by-hand-content{flex:1;padding:28px 24px;max-width:1000px;margin:0 auto;width:100%}.add-by-hand-form{display:flex;flex-direction:column;gap:28px}.add-by-hand-step{background:var(--app-surface);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0}.add-by-hand-step-title{display:flex;align-items:center;gap:12px;margin:0 0 8px;font-size:16px;font-weight:600;color:#0f172a}.add-by-hand-step-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--app-accent);color:#fff;font-size:14px;font-weight:600}.add-by-hand-step-desc{margin:0 0 20px;font-size:14px;color:#64748b;line-height:1.5}.add-by-hand-identifier-row{display:flex;gap:12px;align-items:center}.add-by-hand-identifier-input{flex:1;padding:12px 16px;border:1px solid var(--app-input-border);border-radius:8px;font-size:15px;font-family:ui-monospace,monospace;background-color:var(--app-input-bg);color:var(--app-input-text);transition:border-color .15s,box-shadow .15s}.add-by-hand-identifier-input:focus{outline:none;border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-alpha-15)}.add-by-hand-identifier-input::-moz-placeholder{color:#94a3b8}.add-by-hand-identifier-input::placeholder{color:#94a3b8}.add-by-hand-identifier-input[aria-invalid=true]{border-color:#dc2626}.add-by-hand-validate-btn{padding:12px 24px;font-size:14px;font-weight:600;color:#fff;background:var(--app-accent);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.add-by-hand-validate-btn:hover:not(:disabled){background:var(--app-accent-hover)}.add-by-hand-validate-btn:disabled{opacity:.5;cursor:not-allowed}.add-by-hand-identifier-ok{margin:12px 0 0;font-size:14px;color:#059669;font-weight:500}.add-by-hand-error{margin-top:12px;padding:14px 18px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;line-height:1.5}.add-by-hand-actions{display:flex;justify-content:flex-end;padding-top:8px}.add-by-hand-submit{padding:14px 32px;border:none;border-radius:10px;background:var(--app-accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-by-hand-submit:hover:not(:disabled){background:var(--app-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--app-accent-alpha-35)}.add-by-hand-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}@media(prefers-color-scheme:dark){.add-by-hand-page{background:var(--app-bg)}.add-by-hand-step{background:#1e293b;border-color:#334155}.add-by-hand-step-title{color:#f8fafc}.add-by-hand-step-desc{color:#94a3b8}.add-by-hand-identifier-input{background:#0f172a;border-color:#334155;color:#f8fafc}.add-by-hand-identifier-input::-moz-placeholder{color:#64748b}.add-by-hand-identifier-input::placeholder{color:#64748b}.add-by-hand-error{background:#450a0a;border-color:#991b1b;color:#fca5a5}.add-custom-place-select,.add-custom-datetime-input{background:#0f172a;border-color:#334155;color:#f8fafc}}.add-custom-create-only-actions{margin-top:8px;padding:0 4px}.add-custom-confirm-code{font-family:ui-monospace,monospace;font-size:13px;word-break:break-all}.add-custom-place-label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:8px}.add-custom-place-select{width:100%;padding:12px 14px;border:1px solid var(--app-input-border);border-radius:8px;font-size:14px;background-color:var(--app-input-bg);color:var(--app-input-text)}.add-custom-fields-list{display:flex;flex-direction:column;gap:16px}.add-custom-bool{display:flex;align-items:center;gap:10px;font-size:14px;color:#334155;cursor:pointer}.add-custom-datetime-wrap{max-width:420px}.add-custom-datetime-input{width:100%;padding:12px 14px;border:1px solid var(--app-input-border);border-radius:8px;font-size:14px;font-family:inherit;background-color:var(--app-input-bg);color:var(--app-input-text)}.add-custom-file-wrap{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.add-custom-file-input{width:100%;max-width:100%;font-size:.9375rem}.add-custom-file-chosen{margin:0;font-size:.8125rem;color:var(--app-text-muted)}.add-custom-select-wrap{max-width:420px}.add-custom-radio-fieldset{border:none;margin:0;padding:0;max-width:480px}.add-custom-radio-fieldset legend{padding:0}.add-custom-radio-options{display:flex;flex-direction:column;gap:10px;margin-top:8px}.meter-type-selector{display:flex;gap:24px;min-height:420px}.meter-type-selector-list-card{flex:0 0 280px;background:var(--app-surface);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden}.meter-type-selector-add-btn{width:100%;padding:12px 16px;font-size:14px;font-weight:600;color:#fff;background:#10b981;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:16px}.meter-type-selector-add-btn:hover{background:#059669;transform:translateY(-1px)}.meter-type-selector-list{flex:1;margin:0;padding:0;list-style:none;overflow-y:auto;display:flex;flex-direction:column;gap:0}.meter-type-selector-list-item{display:block;width:100%;padding:12px 16px;border:none;border-bottom:1px solid #e2e8f0;border-radius:0;background:#f8fafc;color:#334155;font-size:14px;font-weight:500;text-align:left;cursor:pointer;transition:background-color .15s ease,color .15s ease}.meter-type-selector-list-item:last-child{border-bottom:none}.meter-type-selector-list-item:hover{background:#eff6ff;color:var(--app-accent)}.meter-type-selector-list-item.selected{background:var(--app-accent);color:#fff}.meter-type-selector-list-item.selected:hover{background:var(--app-accent-hover);color:#fff}.meter-type-selector-loading,.meter-type-selector-empty{margin:24px 0;color:#64748b;font-size:14px;text-align:center}.meter-type-selector-info-card{flex:1;min-width:0;background:var(--app-surface);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden}.meter-type-selector-info-panel{flex:1;min-height:0;overflow-y:auto}.meter-type-selector-info-placeholder{display:flex;align-items:center;justify-content:center;min-height:280px;padding:24px}.meter-type-selector-info-placeholder p{margin:0;color:#94a3b8;font-size:14px;text-align:center;max-width:260px}.meter-type-selector-info-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;min-height:280px;padding:24px}.meter-type-selector-info-empty-text{margin:0;color:#64748b;font-size:14px;text-align:center}.meter-type-selector-add-btn-center{padding:14px 28px;font-size:15px;font-weight:600;color:#fff;background:var(--app-accent);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.meter-type-selector-add-btn-center:hover{background:var(--app-accent-hover);transform:translateY(-1px)}.meter-type-selector-info-content{padding:4px 0 0}.meter-type-selector-info-content h4{margin:20px 0 10px;font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.meter-type-selector-info-content h4:first-child{margin-top:0}.meter-type-selector-info-block{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px 24px}.meter-type-selector-info-limits{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.meter-type-selector-info-row{display:flex;flex-direction:column;gap:2px}.meter-type-selector-info-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.meter-type-selector-info-value{font-size:14px;font-weight:500;color:#0f172a}@media(max-width:768px){.meter-type-selector{flex-direction:column;min-height:auto}.meter-type-selector-list-card{max-height:240px}.meter-type-selector-list{max-height:160px}}@media(prefers-color-scheme:dark){.meter-type-selector-list-card,.meter-type-selector-info-card{background:#1e293b;border-color:#334155}.meter-type-selector-add-btn{background:#059669}.meter-type-selector-add-btn:hover{background:#047857}.meter-type-selector-list-item{background:#0f172a;border-bottom-color:#334155;color:#e2e8f0}.meter-type-selector-list-item:hover{background:#1e3a8a;color:var(--app-accent)}.meter-type-selector-list-item.selected{background:var(--app-accent);color:#fff}.meter-type-selector-loading,.meter-type-selector-empty{color:#94a3b8}.meter-type-selector-info-placeholder p{color:#64748b}.meter-type-selector-info-empty-text,.meter-type-selector-info-content h4{color:#94a3b8}.meter-type-selector-info-label{color:#64748b}.meter-type-selector-info-value{color:#f8fafc}}.purchase-groups-list-page{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--app-bg)}.purchase-groups-list-content{flex:1;padding:24px;width:100%;max-width:100%;box-sizing:border-box}.purchase-groups-list-filters{margin:0 0 1rem}.purchase-groups-list-filters .meter-table-filters-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));max-width:min(100%,960px)}.purchase-groups-list-loading,.purchase-groups-list-error,.purchase-groups-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1.5rem;text-align:center;color:var(--app-text-muted)}.purchase-groups-list-spinner{width:40px;height:40px;border:3px solid var(--app-border);border-top-color:var(--app-accent);border-radius:50%;animation:purchase-groups-list-spin .8s linear infinite}@keyframes purchase-groups-list-spin{to{transform:rotate(360deg)}}.purchase-groups-list-error p{margin:0;color:#b91c1c}.purchase-groups-list-retry{padding:.5rem 1rem;background:var(--app-accent);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;font-family:inherit}.purchase-groups-list-retry:hover{background:var(--app-accent-hover)}.purchase-groups-list-empty p{margin:0}.purchase-groups-list-cards{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.purchase-groups-table-wrapper{margin:0}.purchase-groups-list-pagination{margin-top:1rem}.purchase-groups-table{min-width:720px}.purchase-groups-table-th-actions{min-width:14rem;text-align:right;white-space:nowrap}.purchase-groups-table-td-actions{vertical-align:middle;text-align:right}.purchase-groups-list-row-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px}.purchase-groups-table-th-expand{width:3rem;padding:.75rem .5rem!important;text-align:center;vertical-align:middle}.purchase-groups-table-td-expand{width:3rem;padding:.5rem!important;text-align:center;vertical-align:middle}.purchase-groups-table-expand-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--app-border);border-radius:6px;background:var(--app-surface);color:var(--app-text-muted);font-size:1.25rem;font-weight:600;line-height:1;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;font-family:inherit}.purchase-groups-table-expand-btn:hover{background:var(--app-bg);border-color:var(--app-text-muted)}.purchase-groups-table-expand-btn[aria-expanded=true]{background:var(--app-accent-bg);border-color:var(--app-accent);color:var(--app-accent)}.purchase-groups-table-expand-icon{display:block}.purchase-groups-table-name{font-weight:600;color:var(--app-text)}.purchase-groups-table-row-clickable{cursor:pointer}.purchase-groups-table-row-expanded{background-color:var(--app-bg)}.purchase-groups-table-detail-row{background-color:var(--app-bg);border-bottom:1px solid var(--app-border)}.purchase-groups-table-detail-row:hover{background-color:var(--app-bg)}.purchase-groups-table-detail-cell{padding:0!important;vertical-align:top;border-bottom:1px solid var(--app-border)}.purchase-groups-table-detail-cell .purchase-group-summary{border-top:none}.purchase-groups-list-receive-btn{padding:8px 14px;border:1px solid var(--app-accent);border-radius:8px;background:var(--app-accent-bg);color:var(--app-accent);font-weight:600;cursor:pointer;font-family:inherit}.purchase-groups-list-receive-btn:hover:not(:disabled){background:var(--app-accent);color:#fff}.purchase-groups-list-receive-btn:disabled{opacity:.7;cursor:not-allowed}.purchase-groups-list-accept-btn{padding:8px 14px;border:1px solid #16a34a;border-radius:8px;background:#16a34a1f;color:#15803d;font-weight:600;cursor:pointer;font-family:inherit}.purchase-groups-list-accept-btn:hover:not(:disabled){background:#16a34a;color:#fff}.purchase-groups-list-accept-btn:disabled{opacity:.7;cursor:not-allowed}.purchase-groups-list-return-btn{padding:8px 14px;border:1px solid #b45309;border-radius:8px;background:#b453091a;color:#9a3412;font-weight:600;cursor:pointer;font-family:inherit}.purchase-groups-list-return-btn:hover:not(:disabled){background:#d97706;border-color:#d97706;color:#fff}.purchase-groups-list-return-btn:disabled{opacity:.7;cursor:not-allowed}.purchase-groups-list-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.purchase-groups-list-dialog{background:var(--app-surface);border-radius:12px;box-shadow:0 20px 25px -5px var(--app-shadow),0 10px 10px -5px var(--app-shadow);max-width:440px;width:100%;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--app-border)}.purchase-groups-list-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--app-border)}.purchase-groups-list-dialog-title{margin:0;font-size:18px;font-weight:600;color:var(--app-text)}.purchase-groups-list-dialog-close{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:20px;line-height:1;color:var(--app-text-muted);border-radius:6px}.purchase-groups-list-dialog-close:hover:not(:disabled){background:var(--app-bg);color:var(--app-text)}.purchase-groups-list-dialog-content{padding:20px 24px}.purchase-groups-list-dialog-summary{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--app-text-muted)}.purchase-groups-list-dialog-info{margin:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 12px}.purchase-groups-list-dialog-info div{display:flex;flex-direction:column;gap:4px}.purchase-groups-list-dialog-info dt{margin:0;font-size:12px;font-weight:500;color:var(--app-text-muted);text-transform:uppercase}.purchase-groups-list-dialog-info dd{margin:0;font-size:14px;color:var(--app-text);font-weight:500}.purchase-groups-list-dialog-place{margin-top:14px}.purchase-groups-list-dialog-place-label{display:block;font-size:14px;font-weight:600;color:var(--app-text);margin-bottom:8px}.purchase-groups-list-dialog-place-select{width:100%;padding:10px 12px;font-size:14px;font-family:inherit;border:1px solid var(--app-border);border-radius:8px;background:var(--app-input-bg);color:var(--app-input-text)}.purchase-groups-list-dialog-place-loading{margin:0;color:var(--app-text-muted);font-size:14px}.purchase-groups-list-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--app-border);background-color:var(--app-input-bg)}.purchase-groups-list-dialog-btn{min-width:110px;height:38px;border-radius:8px;font-weight:600;font-family:inherit;cursor:pointer}.purchase-groups-list-dialog-btn-cancel{background:var(--app-surface);border:1px solid var(--app-border);color:var(--app-text-muted)}.purchase-groups-list-dialog-btn-cancel:hover:not(:disabled){background:var(--app-bg)}.purchase-groups-list-dialog-btn-confirm{background:var(--app-accent);border:none;color:#fff}.purchase-groups-list-dialog-btn-confirm:hover:not(:disabled){background:var(--app-accent-hover)}.purchase-groups-list-dialog-btn:disabled,.purchase-groups-list-dialog-close:disabled{opacity:.7;cursor:not-allowed}.purchase-groups-table .meter-table-status-accepted{background-color:#d1fae5;color:#065f46}.purchase-groups-table .meter-table-status-rejected{background-color:#fee2e2;color:#dc2626}.app{width:100%;height:100vh;margin:0;padding:0;overflow:hidden;display:flex;position:relative;z-index:0;font-family:inherit;color:var(--app-text)}.app:before{content:"";position:fixed;inset:0;background-image:url(https://upload.wikimedia.org/wikipedia/commons/thumb/9/96/Flag_of_the_United_States_%28DDD-F-416E_specifications%29.svg/1920px-Flag_of_the_United_States_%28DDD-F-416E_specifications%29.svg.png);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:-1;filter:saturate(1.05) contrast(1.05)}:root[data-proud-american=true] .app:before{opacity:.22}.app-content{flex:1;margin-left:var(--app-sidebar-expanded-width);height:100vh;overflow-y:auto;font-family:inherit;color:var(--app-text);background-color:var(--app-bg);background-image:radial-gradient(ellipse 92% 52% at 100% -8%,var(--app-accent-bg) 0%,transparent 52%),radial-gradient(ellipse 65% 42% at -5% 102%,rgba(10,61,102,.07) 0%,transparent 48%),radial-gradient(ellipse 88% 48% at 50% -12%,var(--app-page-highlight) 0%,transparent 46%);background-repeat:no-repeat;background-size:100% 100%;transition:margin-left .3s ease,background-color .2s ease;display:flex;flex-direction:column}.app-header{background:var(--app-surface);border-bottom:1px solid color-mix(in srgb,var(--app-border) 78%,var(--app-accent) 22%);box-shadow:0 1px #ffffff0a inset;display:flex;justify-content:flex-end;align-items:center;flex-shrink:0}[data-theme=dark] .app-header{box-shadow:none}@media(prefers-color-scheme:dark){:root:not([data-theme]) .app-header{box-shadow:none}}.app:has(.sidebar-collapsed) .app-content{margin-left:80px}.app-content>*:not(.app-header){flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.view-container{padding:2rem}.view-container h1{margin:0 0 1rem;font-size:2rem;font-weight:600;color:var(--app-text)}.view-container p{color:var(--app-text-muted);font-size:1rem}@media(max-width:768px){.app-content{margin-left:80px}}
