:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--color-primary: #007bff;--color-primary-light: rgba(0, 123, 255, .1);--color-secondary: #6c757d;--color-success: #28a745;--color-warning: #ffc107;--color-error: #dc3545;--color-error-light: rgba(220, 53, 69, .1);--color-info: #17a2b8;--color-background: #f5f5f5;--color-surface: #ffffff;--color-border: #e0e0e0;--color-border-light: #f0f0f0;--color-hover: rgba(0, 0, 0, .05);--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-disabled: #999999;color-scheme:light dark;color:var(--color-text-primary);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}html{width:100%;height:100%;margin:0;padding:0}body{margin:0!important;padding:0!important;width:100%;height:100%;min-width:320px;font-family:inherit;background-color:var(--color-background);color:var(--color-text-primary);overflow-x:hidden}#root{width:100%;height:100%;margin:0;padding:0}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{border-radius:6px;border:1px solid var(--color-border);padding:.5rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;background-color:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:all .2s ease}button:hover{background-color:var(--color-hover);border-color:var(--color-primary)}button:focus,button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:disabled{opacity:.6;cursor:not-allowed}h1,h2,h3,h4,h5,h6{margin:0 0 1rem;font-weight:600;line-height:1.2;color:var(--color-text-primary)}p{margin:0 0 1rem;color:var(--color-text-secondary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-disabled)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.data-table{width:100%;background:var(--color-surface, #ffffff);border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.data-list__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--color-background-alt, #f9fafb);border-bottom:1px solid var(--color-border, #e5e7eb)}.data-list__header-left{display:flex;align-items:center}.data-list__header-actions{margin-right:16px}.data-list__title-section{flex:1}.data-list__title{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #111827)}.data-table__bulk-actions{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-primary-light, #f0f9ff);border-bottom:1px solid var(--color-border, #e5e7eb)}.data-table__header-actions-cell{display:flex;align-items:center;gap:8px}.data-table__header-actions-inline{margin-left:auto;display:flex;gap:8px;align-items:center}@media (max-width: 768px){.data-table__header-actions-inline{width:100%;flex-direction:column;gap:6px}.data-table__header-actions-inline .user-list__btn{width:100%}}.data-table__selected-count{font-weight:500;color:var(--color-text-primary, #111827)}.data-table__bulk-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.data-table__bulk-btn--primary{background:var(--color-primary, #3b82f6);color:#fff}.data-table__bulk-btn--primary:hover{background:var(--color-primary-dark, #2563eb)}.data-table__bulk-btn--secondary{background:var(--color-secondary, #6b7280);color:#fff}.data-table__bulk-btn--secondary:hover{background:var(--color-secondary-dark, #4b5563)}.data-table__bulk-btn--success{background:var(--color-success, #10b981);color:#fff}.data-table__bulk-btn--success:hover{background:var(--color-success-dark, #059669)}.data-table__bulk-btn--warning{background:var(--color-warning, #f59e0b);color:#fff}.data-table__bulk-btn--warning:hover{background:var(--color-warning-dark, #d97706)}.data-table__bulk-btn--error{background:var(--color-error, #ef4444);color:#fff}.data-table__bulk-btn--error:hover{background:var(--color-error-dark, #dc2626)}.data-table__bulk-icon{font-size:16px}.data-table__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;scrollbar-width:thin;scrollbar-color:var(--color-primary, #3b82f6) var(--color-background-alt, #f9fafb)}.data-table__wrapper::-webkit-scrollbar{height:8px}.data-table__wrapper::-webkit-scrollbar-track{background:var(--color-background-alt, #f9fafb);border-radius:4px}.data-table__wrapper::-webkit-scrollbar-thumb{background:var(--color-primary, #3b82f6);border-radius:4px}.data-table__wrapper::-webkit-scrollbar-thumb:hover{background:var(--color-primary-dark, #2563eb)}.data-table__table{width:100%;border-collapse:collapse;font-size:14px;min-width:max-content}.data-table__table--striped tbody tr:nth-child(2n){background:var(--color-background-alt, #f8fafc)}.data-table__table--hoverable tbody tr:hover{background:var(--color-background-hover, #f1f5f9)!important;color:var(--color-text-primary, #111827)!important}.data-table__table--hoverable tbody tr:hover .data-table__cell{color:var(--color-text-primary, #111827)!important}.data-table__row--clickable{cursor:pointer;transition:background-color .2s ease}.data-table__row--clickable:hover{background:var(--color-primary-50, #eff6ff)!important;color:var(--color-text-primary, #111827)!important}.data-table__row--clickable:hover .data-table__cell{color:var(--color-text-primary, #111827)!important}.data-table__table--striped tbody tr:nth-child(2n) .data-table__cell{color:var(--color-text-primary, #111827)}.data-table__table--hoverable.data-table__table--striped tbody tr:nth-child(2n):hover{background:var(--color-primary-50, #eff6ff)!important;color:var(--color-text-primary, #111827)!important}.data-table__table--hoverable.data-table__table--striped tbody tr:nth-child(2n):hover .data-table__cell{color:var(--color-text-primary, #111827)!important}.data-table__table--hoverable.data-table__table--striped tbody tr:nth-child(odd):hover{background:var(--color-primary-50, #eff6ff)!important;color:var(--color-text-primary, #111827)!important}.data-table__table--hoverable.data-table__table--striped tbody tr:nth-child(odd):hover .data-table__cell{color:var(--color-text-primary, #111827)!important}.data-table__head{background:var(--color-background-alt, #f9fafb);border-bottom:2px solid var(--color-border, #e5e7eb)}.data-table__header{padding:12px 16px;text-align:left;font-weight:600;color:var(--color-text-primary, #111827);border-bottom:1px solid var(--color-border, #e5e7eb);white-space:nowrap}.data-table__header--sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.data-table__header--sortable:hover{background:var(--color-background-hover, #f3f4f6)}.data-table__header--select{width:48px;text-align:center}.data-table__header--actions{width:120px;text-align:center}.data-table__header-content{display:flex;align-items:center;gap:8px}.data-table__sort-indicator{font-size:12px;color:var(--color-primary, #3b82f6)}.data-table__body{background:var(--color-surface, #ffffff)}.data-table__row{border-bottom:1px solid var(--color-border, #e5e7eb);transition:background-color .2s ease}.data-table__cell{padding:12px 16px;color:var(--color-text-primary, #111827);vertical-align:middle}.data-table__cell--select{text-align:center;width:48px}.data-table__cell--actions{text-align:center;width:120px}.data-table__actions{display:flex;align-items:center;justify-content:center;gap:8px}.data-table__action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;background:transparent;cursor:pointer;transition:all .2s ease;font-size:14px}.data-table__action-btn:hover{background:var(--color-background-hover, #f3f4f6)}.data-table__action-btn--view:hover{background:var(--color-info-light, #dbeafe);color:var(--color-info, #3b82f6)}.data-table__action-btn--edit:hover{background:var(--color-warning-light, #fef3c7);color:var(--color-warning, #f59e0b)}.data-table__action-btn--delete:hover{background:var(--color-error-light, #fee2e2);color:var(--color-error, #ef4444)}.data-table__pagination{display:flex;align-items:center;justify-content:space-between;padding:16px;border-top:1px solid var(--color-border, #e5e7eb);background:var(--color-background-alt, #f9fafb)}.data-table__pagination-info{font-size:14px;color:var(--color-text-secondary, #6b7280)}.data-table__pagination-controls{display:flex;align-items:center;gap:4px}.data-table__page-btn{padding:8px 12px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);color:var(--color-text-primary, #111827);border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:14px}.data-table__page-btn:hover:not(:disabled){background:var(--color-background-hover, #f3f4f6);border-color:var(--color-primary, #3b82f6)}.data-table__page-btn:disabled{opacity:.5;cursor:not-allowed}.data-table__page-btn--active{background:var(--color-primary, #3b82f6);color:#fff;border-color:var(--color-primary, #3b82f6)}.data-table__page-size{display:flex;align-items:center;gap:8px}.data-table__page-size-select{padding:6px 8px;border:1px solid var(--color-border, #e5e7eb);border-radius:4px;background:var(--color-surface, #ffffff);font-size:14px}.data-table__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;text-align:center}.data-table__spinner{width:32px;height:32px;border:3px solid var(--color-border, #e5e7eb);border-top:3px solid var(--color-primary, #3b82f6);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.data-table__error{padding:48px;text-align:center;color:var(--color-error, #ef4444)}.data-table__empty{padding:48px;text-align:center;color:var(--color-text-secondary, #6b7280)}.data-table--mobile{box-shadow:none;border-radius:0}.data-table__cards{display:flex;flex-direction:column;gap:16px;padding:16px}.data-table__card{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a;position:relative}.data-table__card-select{position:absolute;top:12px;right:12px}.data-table__card-content{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.data-table__card-field{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.data-table__card-label{font-weight:500;color:var(--color-text-secondary, #6b7280);min-width:80px;flex-shrink:0}.data-table__card-value{color:var(--color-text-primary, #111827);text-align:right;word-break:break-word}.data-table__card-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:12px;border-top:1px solid var(--color-border, #e5e7eb)}.data-table__pagination--mobile{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--color-background-alt, #f9fafb);border-top:1px solid var(--color-border, #e5e7eb)}.data-table__page-info{font-size:14px;color:var(--color-text-secondary, #6b7280)}@media (max-width: 768px){.data-table__pagination{flex-direction:column;gap:16px;align-items:stretch}.data-table__pagination-info{text-align:center}.data-table__pagination-controls,.data-table__page-size{justify-content:center}.data-table__bulk-actions{flex-wrap:wrap;gap:8px}.data-table__bulk-btn{flex:1;min-width:120px;justify-content:center}}@media (max-width: 480px){.data-table__card{padding:12px}.data-table__card-field{flex-direction:column;gap:4px}.data-table__card-label{min-width:auto}.data-table__card-value{text-align:left}.data-table__action-btn{width:40px;height:40px;font-size:16px}}@media (prefers-contrast: high){.data-table{border:2px solid var(--color-border, #000000)}.data-table__header,.data-table__cell{border:1px solid var(--color-border, #000000)}.data-table__action-btn:hover{border:2px solid var(--color-primary, #000000)}}@media (prefers-reduced-motion: reduce){.data-table__spinner{animation:none}.data-table__action-btn,.data-table__page-btn,.data-table__bulk-btn{transition:none}}@media print{.data-table__bulk-actions,.data-table__pagination,.data-table__actions{display:none}.data-table{box-shadow:none;border:1px solid #000}.data-table__table{font-size:12px}}.number-spinner{display:flex;flex-direction:column;gap:0;margin:0;padding:0 .25rem;flex-shrink:0}.number-spinner__button{display:flex;align-items:center;justify-content:center;width:2rem;height:1.2rem;padding:0 .25rem;border:none;border-radius:0;background-color:transparent;color:#666;cursor:pointer;transition:all .15s ease-in-out;flex-shrink:0}.number-spinner__button:hover:not(:disabled){background-color:#00000014;color:#333}.number-spinner__button:focus:not(:disabled){outline:none;background-color:#00000014}.number-spinner__button:active:not(:disabled){background-color:#0000001f}.number-spinner__button:disabled{opacity:.5;cursor:not-allowed}.number-spinner__button svg{width:1rem;height:1rem}.number-spinner__button--up{border-bottom:none;border-radius:0}.number-spinner__button--down{border-radius:0}@media (max-width: 640px){.number-spinner{margin-left:.375rem;gap:.125rem}.number-spinner__button{width:1.625rem;height:1.125rem}.number-spinner__button svg{width:.8125rem;height:.8125rem}}.url-link{display:inline-block;color:var(--md-color-secondary);text-decoration:none;cursor:pointer;padding:.625rem .75rem;border-radius:.375rem;transition:all .15s ease-in-out;word-break:break-all}.url-link:hover{color:var(--md-color-secondary-dark);text-decoration:underline;background-color:var(--md-color-background-light)}.url-link:focus{outline:none;color:var(--md-color-secondary-dark);box-shadow:0 0 0 3px var(--md-color-focus-ring)}.url-link:active{color:var(--md-color-secondary-darker)}.url-link__input{width:100%;padding:.625rem .75rem;border:1px solid var(--md-color-border);border-radius:.375rem;font-size:.875rem;line-height:1.5;color:var(--md-color-text-primary);background-color:var(--md-color-surface);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.url-link__input:focus{outline:none;border-color:var(--md-color-secondary);box-shadow:0 0 0 3px var(--md-color-focus-ring);background-color:var(--md-color-background-highlight)}.url-link__input:disabled{background-color:var(--md-color-border-lighter);color:var(--md-color-text-disabled);cursor:not-allowed}@media (max-width: 640px){.url-link,.url-link__input{font-size:.8125rem;padding:.5rem .625rem}}.toast{position:fixed;bottom:2rem;right:2rem;z-index:9999;min-width:200px;max-width:500px;padding:1rem 2rem;border-radius:8px;box-shadow:0 2px 8px #00000026;font-weight:500;color:#fff;display:flex;align-items:center;animation:toast-slide-in .3s ease-out}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast__message{flex:1;word-break:break-word}.toast--error{background:#f44336}.toast--success{background:#4caf50}.toast--info{background:#2196f3}.toast--warning{background:#ff9800}.toast__close{margin-left:1rem;background:transparent;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .2s}.toast__close:hover{opacity:1}.toast__close:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}@media (max-width: 768px){.toast{left:1rem;right:1rem;bottom:1rem;min-width:auto}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.loading-spinner--fullscreen{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#ffffffe6;z-index:9999;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;width:auto;height:auto}.loading-spinner__spinner{width:var(--spinner-size, 40px);height:var(--spinner-size, 40px);border:4px solid var(--color-border, #e0e0e0);border-top:4px solid var(--color-primary, #007bff);border-radius:50%;animation:spin 1s linear infinite}.loading-spinner__message{margin:0;font-size:.875rem;color:var(--color-text-secondary, #666666);text-align:center;font-weight:500}@media (max-width: 768px){.loading-spinner{padding:1.5rem}.loading-spinner__message{font-size:.8125rem}}.country-select-wrapper{position:relative;width:100%}.country-select{width:100%;padding:1.25rem 1rem .75rem;border:1px solid var(--md-color-outline);border-radius:4px;font-size:1rem;background-color:var(--md-color-surface);color:var(--md-color-on-surface);transition:border-color .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1);font-family:inherit}.country-select:focus{outline:none;border-color:var(--md-color-primary);box-shadow:0 0 0 1px var(--md-color-primary)}.country-select:disabled{background-color:var(--md-color-surface-dim);color:var(--md-color-on-surface-variant);cursor:not-allowed;opacity:.38;border-color:var(--md-color-outline)}.country-select--error{border-color:var(--md-color-error)}.country-select--error:focus{border-color:var(--md-color-error);box-shadow:0 0 0 1px var(--md-color-error)}.country-select-error{display:block;color:var(--md-color-error);font-size:.75rem;margin-top:.375rem}.image-upload{width:100%}.image-upload__dropzone{position:relative;border:2px dashed var(--color-border, #d1d5db);border-radius:8px;background:var(--color-surface, #ffffff);transition:all .2s ease;cursor:pointer;min-height:200px;display:flex;align-items:center;justify-content:center;max-width:200px;max-height:200px}.image-upload__dropzone:hover{border-color:var(--color-primary, #3b82f6);background:var(--color-primary-light, #f0f9ff)}.image-upload__dropzone--dragging{border-color:var(--color-primary, #3b82f6);background:var(--color-primary-light, #f0f9ff);transform:scale(1.02)}.image-upload__dropzone--disabled{cursor:not-allowed;opacity:.6;background:var(--color-background-disabled, #f9fafb)}.image-upload__dropzone--disabled:hover{border-color:var(--color-border, #d1d5db);background:var(--color-background-disabled, #f9fafb);transform:none}.image-upload__dropzone--has-image{min-height:250px;border-style:solid;border-color:var(--color-border, #d1d5db)}.image-upload__input{display:none}.image-upload__placeholder{text-align:center;padding:2rem}.image-upload__icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.image-upload__text{font-size:1rem;font-weight:500;color:var(--color-text-primary, #111827);margin-bottom:.5rem}.image-upload__hint{font-size:.875rem;color:var(--color-text-secondary, #6b7280);line-height:1.4}.image-upload__loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.image-upload__spinner{width:32px;height:32px;border:3px solid var(--color-border, #d1d5db);border-top:3px solid var(--color-primary, #3b82f6);border-radius:50%;animation:spin 1s linear infinite}.image-upload__preview{position:relative;width:100%;height:100%;min-height:250px;display:flex;align-items:center;justify-content:center}.image-upload__image{max-width:100%;max-height:200px;object-fit:contain;border-radius:4px;box-shadow:0 2px 8px #0000001a}.image-upload__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;border-radius:8px}.image-upload__preview:hover .image-upload__overlay{opacity:1}.image-upload__remove{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:50%;background:#ffffffe6;color:var(--color-error, #ef4444);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.image-upload__remove:hover{background:var(--color-error, #ef4444);color:#fff;transform:scale(1.1)}.image-upload__change-text{color:#fff;font-size:.875rem;font-weight:500;text-align:center;margin:0}@media (max-width: 768px){.image-upload__dropzone{min-height:150px}.image-upload__dropzone--has-image{min-height:200px}.image-upload__image{max-height:150px}.image-upload__placeholder{padding:1.5rem}.image-upload__icon{font-size:2.5rem}.image-upload__text{font-size:.875rem}.image-upload__hint{font-size:.75rem}}.image-upload--error .image-upload__dropzone{border-color:var(--color-error, #ef4444);background:var(--color-error-light, #fef2f2)}.image-upload--success .image-upload__dropzone{border-color:var(--color-success, #10b981)}.image-upload__dropzone:focus-within{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.search-filter{background:var(--color-surface, #ffffff);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.search-filter__main{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--color-border, #e5e7eb);width:100%;min-height:60px}.search-filter__search-group{position:relative;flex:1;display:flex;align-items:center;background:var(--color-background-alt, #f9fafb);border:1px solid var(--color-border, #e5e7eb);border-radius:6px;transition:all .2s ease}.search-filter__search-group--focused{border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.search-filter__search-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--color-text-secondary, #6b7280);font-size:16px;flex-shrink:0}.search-filter__search-input{flex:1;border:none;background:transparent;padding:10px 0;font-size:14px;color:var(--color-text-primary, #111827);outline:none}.search-filter__search-input::placeholder{color:var(--color-text-placeholder, #9ca3af)}.search-filter__search-clear{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:var(--color-text-secondary, #6b7280);transition:all .2s ease;margin-right:4px}.search-filter__search-clear:hover{background:var(--color-background-hover, #f3f4f6);color:var(--color-text-primary, #111827)}.search-filter__controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-filter__filter-toggle{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);color:var(--color-text-primary, #111827);border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.search-filter__filter-toggle:hover{background:var(--color-background-hover, #f3f4f6);border-color:var(--color-primary, #3b82f6)}.search-filter__filter-toggle--active{background:var(--color-primary, #3b82f6);color:#fff;border-color:var(--color-primary, #3b82f6)}.search-filter__filter-badge{display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:var(--color-error, #ef4444);color:#fff;border-radius:9px;font-size:11px;font-weight:600;padding:0 4px}.search-filter__clear-all{padding:8px 12px;border:1px solid var(--color-error, #ef4444);background:transparent;color:var(--color-error, #ef4444);border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.search-filter__clear-all:hover{background:var(--color-error, #ef4444);color:#fff}.advanced-filter{padding:16px}.advanced-filter__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.advanced-filter__title{font-size:16px;font-weight:600;color:var(--color-text-primary, #111827);margin:0}.advanced-filter__reset{padding:6px 12px;border:1px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);color:var(--color-text-secondary, #6b7280);border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease}.advanced-filter__reset:hover{background:var(--color-background-hover, #f3f4f6);color:var(--color-text-primary, #111827)}.advanced-filter__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.advanced-filter__field{display:flex;flex-direction:column;gap:6px}.advanced-filter__label{font-size:13px;font-weight:500;color:var(--color-text-primary, #111827)}.advanced-filter__input-group{position:relative;display:flex;align-items:center}.advanced-filter__input,.advanced-filter__select{width:100%;padding:8px 10px;border:1px solid var(--color-border, #e5e7eb);border-radius:4px;font-size:13px;color:var(--color-text-primary, #111827);background:var(--color-surface, #ffffff);transition:all .2s ease}.advanced-filter__input:focus,.advanced-filter__select:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 2px #3b82f61a}.advanced-filter__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:12px;padding-right:28px}.advanced-filter__clear{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;border-radius:2px;cursor:pointer;color:var(--color-text-secondary, #6b7280);font-size:12px;transition:all .2s ease}.advanced-filter__clear:hover{background:var(--color-background-hover, #f3f4f6);color:var(--color-text-primary, #111827)}@media (max-width: 768px){.search-filter__main{flex-direction:column;gap:12px;align-items:stretch}.advanced-filter__grid{grid-template-columns:1fr;gap:12px}}.hamburger-icon{width:24px;height:18px;position:relative;transform:rotate(0);transition:transform .3s ease-in-out;cursor:pointer;will-change:transform;contain:strict;transform-style:preserve-3d;backface-visibility:hidden}.hamburger-line{display:block;position:absolute;height:2px;width:100%;background:currentColor;border-radius:1px;opacity:1;left:0;transform:rotate(0);transition:transform .25s ease-in-out,opacity .25s ease-in-out;will-change:transform,opacity;contain:strict;transform-style:preserve-3d;backface-visibility:hidden}.hamburger-line--top{top:0;transform-origin:left center}.hamburger-line--middle{top:8px;transform-origin:left center}.hamburger-line--bottom{top:16px;transform-origin:left center}.hamburger-icon.open .hamburger-line--top{top:8px;left:3px;transform:rotate3d(0,0,1,45deg)}.hamburger-icon.open .hamburger-line--middle{opacity:0;transform:translate3d(-60px,0,0)}.hamburger-icon.open .hamburger-line--bottom{top:8px;left:3px;transform:rotate3d(0,0,1,-45deg)}.hamburger-icon:focus-visible{outline:2px solid var(--color-focus, #007bff);outline-offset:2px;border-radius:4px}@media (prefers-contrast: high){.hamburger-line{background:currentColor;height:3px}}@media (prefers-reduced-motion: reduce){.hamburger-icon,.hamburger-line{transition:none}}@media (prefers-color-scheme: dark){.hamburger-line{background:var(--color-text-dark, #ffffff)}}:root{--sidebar-header-transition: .3s ease-in-out;--header-height: 64px;--header-z-index: 1000;--dropdown-z-index: 1001}.app-header{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"left center right";align-items:center;height:64px;padding:0;background-color:#94b5e9;border-bottom:1px solid var(--color-border, #e0e0e0);box-shadow:0 1px 3px #0000001a;z-index:2000;flex-shrink:0;overflow:visible;transition:transform var(--sidebar-header-transition, .3s ease-in-out),opacity var(--sidebar-header-transition, .3s ease-in-out);will-change:transform,opacity;contain:layout style;transform:translateZ(0);backface-visibility:hidden}.app-header__left{padding-left:20px;padding-top:5px;grid-area:left;display:flex;align-items:center;gap:1rem;will-change:transform,opacity;contain:layout style;position:relative}.app-header__center{grid-area:center;display:flex;justify-content:center;align-items:center;min-width:0;top:4px;position:relative}.app-header__right{grid-area:right;display:flex;align-items:center;gap:1rem;justify-content:flex-end;min-width:0}.app-header__search{display:flex;align-items:center;top:4px}.search-container{position:relative;display:flex;align-items:center;width:250px;max-width:100%}.search-icon{position:absolute;left:12px;font-size:20px;pointer-events:none;color:#0009}.search-input{width:100%;padding:8px 12px 8px 36px;border:1px solid rgba(255,255,255,.5);border-radius:20px;background-color:#ffffffe6;color:#333;font-size:14px;transition:all .2s ease;outline:none}.search-input::placeholder{color:#00000080}.search-input:focus{background-color:#fff;border-color:#fffc;box-shadow:0 0 0 3px #fff3}.search-input:hover{background-color:#fff}.mic-button{position:absolute;right:8px;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#0009}.mic-button:hover{background-color:#0000000d;color:#000c}.mic-button:focus{outline:2px solid rgba(0,0,0,.3);outline-offset:2px}.mic-button.listening{color:#ef4444;background-color:#ef44441a;animation:pulse-mic 1.5s ease-in-out infinite}@keyframes pulse-mic{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef444400}}.mic-icon{font-size:18px}.search-results-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:#fff;border:1px solid var(--color-border, #e0e0e0);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:var(--dropdown-z-index);max-height:400px;overflow-y:auto;will-change:transform,opacity;contain:layout style;transform:translateZ(0);backface-visibility:hidden}.search-results-list{padding:0;margin:0}.search-result-item{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--color-border-light, #f0f0f0);cursor:pointer;transition:background-color .2s ease}.search-result-item:hover{background-color:var(--color-hover, rgba(0, 0, 0, .02))}.search-result-item:last-child{border-bottom:none}.result-icon{flex-shrink:0;font-size:20px;color:#f59e0b}.result-content{flex:1;min-width:0}.result-name{font-weight:500;color:var(--color-text-primary, #333);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-meta{display:flex;gap:8px;font-size:.75rem;color:var(--color-text-secondary, #666);margin-bottom:4px}.result-type,.result-location{background-color:#0000000d;padding:2px 6px;border-radius:3px}.result-consumption{font-size:.875rem;color:var(--color-text-secondary, #666)}.result-status{flex-shrink:0;font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:4px;text-transform:uppercase}.result-status.active{background-color:#10b9811a;color:#10b981}.result-status.inactive{background-color:#6b72801a;color:#6b7280}.result-status.error{background-color:#ef44441a;color:#ef4444}.no-results{padding:24px 16px;text-align:center;color:var(--color-text-secondary, #666)}.no-results p{margin:0;font-size:.875rem}.search-results-footer{padding:8px 12px;border-top:1px solid var(--color-border, #e0e0e0);text-align:center}.view-all-button{background:none;border:none;color:var(--color-primary, #007bff);font-size:.875rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.app-header__menu-toggle{width:30px;height:40px;border:none;background:none;cursor:pointer;border-radius:8px;transition:background-color .2s ease,transform .2s ease;padding:0;justify-content:center;color:#fff;will-change:background-color,transform;contain:strict;transform:translateZ(0)}.app-header__menu-toggle:hover{background-color:#ffffff1a;transform:translateZ(0) scale(1.05)}.app-header__menu-toggle:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.app-header__brand{display:flex;align-items:center;gap:.5rem;color:#fff}.brand-text{font-size:1.125rem;font-weight:600;white-space:nowrap}.app-header__title{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.app-header__notifications{position:relative}.notification-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;border-radius:50%;transition:background-color .2s ease}.notification-button:hover{background-color:var(--color-hover, rgba(0, 0, 0, .05))}.notification-button:focus{outline:2px solid var(--color-primary, #007bff);outline-offset:2px}.notification-icon{font-size:1.5rem;color:#fff}.notification-badge{position:absolute;top:6px;right:6px;background-color:var(--color-error, #dc3545);color:#fff;font-size:.75rem;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notifications-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background-color:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e0e0e0);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:var(--dropdown-z-index);overflow:hidden;will-change:transform,opacity;contain:layout style;transform:translateZ(0);backface-visibility:hidden}.notifications-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border, #e0e0e0)}.notifications-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary, #333)}.unread-count{font-size:.875rem;color:var(--color-text-secondary, #666)}.notifications-list{max-height:280px;overflow-y:auto}.notification-item{display:flex;padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light, #f0f0f0);transition:background-color .2s ease}.notification-item:hover{background-color:var(--color-hover, rgba(0, 0, 0, .02))}.notification-item:last-child{border-bottom:none}.notification-type{margin-right:.75rem;flex-shrink:0}.notification-type.success .notification-icon{color:#10b981}.notification-type.error .notification-icon{color:#ef4444}.notification-type.warning .notification-icon{color:#f59e0b}.notification-type.info .notification-icon{color:#3b82f6}.notification-content{flex:1;min-width:0}.notification-title{font-weight:500;color:var(--color-text-primary, #333);margin-bottom:.25rem;line-height:1.4}.notification-message{font-size:.875rem;color:var(--color-text-secondary, #666);margin-bottom:.25rem;line-height:1.4}.notification-time{font-size:.75rem;color:var(--color-text-disabled, #999)}.no-notifications{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;color:var(--color-text-secondary, #666)}.no-notifications .icon{font-size:2rem;margin-bottom:.5rem}.no-notifications p{margin:0;font-size:.875rem}.notifications-footer{padding:.75rem 1rem;border-top:1px solid var(--color-border, #e0e0e0);text-align:center}.view-all-button{background:none;border:none;color:var(--color-primary, #007bff);font-size:.875rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s ease}.view-all-button:hover{background-color:var(--color-primary-light, rgba(0, 123, 255, .1))}.app-header__user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.75rem;background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:background-color .2s ease;max-width:200px}.user-menu-trigger:hover{background-color:#ffffff1a}.user-menu-trigger:focus{outline:none}.user-avatar{width:27px;height:27px;border-radius:50%;overflow:hidden;flex-shrink:0;background-color:var(--color-primary, #007bff);display:flex;align-items:center;justify-content:center}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{color:#fff;font-weight:600;font-size:.875rem}.user-info{flex:1;text-align:left;min-width:0}.user-name{font-weight:500;color:#fff;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-arrow{font-size:.75rem;color:#fff;transition:transform .2s ease;flex-shrink:0}.dropdown-arrow.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + 0px);right:-12px;width:240px;background-color:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e0e0e0);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:var(--dropdown-z-index);overflow:hidden;will-change:transform,opacity;contain:layout style;transform:translateZ(0);backface-visibility:hidden}.user-menu-header{padding:1rem;border-bottom:1px solid var(--color-border, #e0e0e0)}.user-avatar-large{width:48px;height:48px;border-radius:50%;overflow:hidden;margin-bottom:.75rem;background-color:var(--color-primary, #007bff);display:flex;align-items:center;justify-content:center}.user-avatar-large img{width:100%;height:100%;object-fit:cover}.user-avatar-large .avatar-initials{font-size:1.25rem}.user-details .user-name{font-size:1rem;font-weight:600;margin-bottom:.25rem;color:var(--color-text-primary, #333)}.user-details .user-email{font-size:.875rem;color:var(--color-text-secondary, #666)}.user-menu-divider{height:1px;background-color:var(--color-border, #e0e0e0)}.user-menu-items{padding:.5rem 0}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.875rem;color:var(--color-text-primary, #333);transition:background-color .2s ease}.user-menu-item:hover{background-color:var(--color-hover, rgba(0, 0, 0, .05))}.user-menu-item:focus{outline:none;background-color:var(--color-hover, rgba(0, 0, 0, .05))}.user-menu-item .icon{font-size:1.25rem;flex-shrink:0;color:var(--color-text-secondary, #666)}.logout-item{color:var(--color-error, #dc3545)}.logout-item:hover{background-color:var(--color-error-light, rgba(220, 53, 69, .1))}.user-menu-footer{padding:.25rem 1rem;background-color:var(--color-hover, rgba(0, 0, 0, .02));min-height:10px}.user-menu-footer .app-version{display:flex;justify-content:center;align-items:center;font-size:.75rem;color:var(--color-text-secondary, #666)}.user-menu-footer .version-number{font-family:monospace}@media (min-width: 1024px){.app-header .app-header__left{display:flex}.app-header{grid-template-columns:auto 1fr auto;grid-template-areas:"left center right"}}@media (max-width: 1023px){.app-header{padding:0}.app-header__search{display:flex}.search-container{width:200px}.app-header__title{font-size:1.125rem}.user-info{display:none}.user-menu-trigger{max-width:none}.notifications-dropdown,.user-menu-dropdown{width:280px}}@media (max-width: 768px){.app-header{padding:0}.brand-text{font-size:1rem}}@media (max-width: 480px){.app-header{padding:0}.app-header__right{gap:.5rem}.app-header__title{font-size:1rem}.notifications-dropdown,.user-menu-dropdown{width:calc(100vw - 2rem);right:-.75rem}}@media (prefers-contrast: high){.app-header{border-bottom-width:2px}.notification-button:focus,.app-header__menu-toggle:focus{outline-width:3px}.user-menu-trigger:focus{outline:none}}@media (prefers-reduced-motion: reduce){.hamburger-line,.dropdown-arrow,.notification-button,.user-menu-trigger,.user-menu-item{transition:none}}.sidebar{position:relative;width:auto;min-width:0;background-color:var(--color-surface, #ffffff);border-right:1px solid var(--color-border, #e0e0e0);display:flex;flex-direction:column;z-index:1100;transition:width .25s ease,min-width .25s ease,transform .25s ease;overflow:hidden;will-change:width,transform;contain:layout style;transform:translateZ(0);backface-visibility:hidden}.sidebar.collapsed{width:64px;min-width:64px}.sidebar.mobile{position:fixed;top:var(--header-height, 64px);left:0;width:var(--sidebar-width, 280px);height:calc(100vh - var(--header-height, 64px));transform:translate3d(-100%,0,0);box-shadow:2px 0 8px #00000026;will-change:transform}.sidebar.mobile:not(.collapsed){transform:translateZ(0)}.sidebar__brand{display:flex;align-items:center;gap:.75rem;flex:1}.brand-icon{font-size:1.5rem;flex-shrink:0}.brand-text{font-weight:600;font-size:1.125rem;color:var(--color-text-primary, #333);white-space:nowrap}.toggle-icon{font-size:.875rem;color:var(--color-text-secondary, #666);transition:transform .3s ease;display:inline-block;transform-origin:50% 50%}.toggle-icon.collapsed,.sidebar.collapsed .toggle-icon{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.sidebar__nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.375rem 0}.sidebar__custom-content{border-bottom:1px solid var(--color-border, #e0e0e0);padding:.75rem 0;flex-shrink:0}.sidebar__custom-content::-webkit-scrollbar{width:4px}.sidebar__custom-content::-webkit-scrollbar-track{background:transparent}.sidebar__custom-content::-webkit-scrollbar-thumb{background-color:#e0e0e0;border-radius:2px}.sidebar__custom-content::-webkit-scrollbar-thumb:hover{background-color:#999}.sidebar-menu{list-style:none;margin:0;padding:0}.sidebar-item{position:relative;margin:0 .5rem .125rem}.sidebar-item--child{margin:0}.sidebar-link{display:flex;align-items:center;padding:.5rem .75rem;border-radius:6px;cursor:pointer;transition:background-color .2s ease,color .2s ease,transform .2s ease;position:relative;text-decoration:none;color:inherit;-webkit-user-select:none;user-select:none;will-change:background-color,color,transform;contain:layout style;transform:translateZ(0)}.sidebar-link:hover{background-color:var(--color-hover, rgba(0, 0, 0, .05));transform:translateZ(0) translate(2px)}.sidebar-link:focus{outline:2px solid var(--color-primary, #007bff);outline-offset:-2px}.sidebar-link.active{background-color:var(--color-primary-light, rgba(0, 123, 255, .1));color:var(--color-primary, #007bff)}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background-color:var(--color-primary, #007bff);border-radius:0 2px 2px 0}.sidebar-link__content{display:flex;align-items:center;width:100%;min-width:0}.sidebar-icon{font-size:1.125rem;margin-right:.625rem;flex-shrink:0;width:20px;text-align:center}.sidebar-label{flex:1;font-weight:500;font-size:.8125rem;color:var(--color-text-primary, #333);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.sidebar-badge{background-color:var(--color-primary, #007bff);color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .375rem;border-radius:10px;margin-left:.5rem;flex-shrink:0}.sidebar-arrow{margin-left:.375rem;font-size:.625rem;color:var(--color-text-secondary, #666);transition:transform .2s ease;flex-shrink:0}.sidebar-arrow.expanded{transform:rotate(180deg)}.sidebar-submenu{list-style:none;margin:0;padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease;will-change:max-height,opacity;contain:layout style}.sidebar-submenu.expanded{max-height:500px}.sidebar-submenu .sidebar-link{margin-left:1.75rem;padding:.375rem .625rem;font-size:.75rem}.sidebar-submenu .sidebar-icon{font-size:.875rem;margin-right:.5rem}.sidebar-tooltip{position:absolute;left:calc(100% + 8px);top:50%;transform:translate3d(0,-50%,0);background-color:var(--color-text-primary, #333);color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease,transform .2s ease;z-index:1000;pointer-events:none;will-change:opacity,visibility,transform;contain:layout style;backface-visibility:hidden}.sidebar-tooltip:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:4px solid transparent;border-right-color:var(--color-text-primary, #333)}.sidebar.collapsed .sidebar-item:hover .sidebar-tooltip{opacity:1;visibility:visible}.tooltip-badge{background-color:var(--color-primary, #007bff);color:#fff;font-size:.75rem;padding:.125rem .375rem;border-radius:8px;margin-left:.5rem}.sidebar.collapsed .sidebar__brand,.sidebar.collapsed .sidebar-label,.sidebar.collapsed .sidebar-badge,.sidebar.collapsed .sidebar-arrow{display:none}.sidebar.collapsed .sidebar-submenu{display:none!important;max-height:0!important}.sidebar.collapsed .sidebar-submenu .sidebar-label{display:none}.sidebar.collapsed .sidebar-link{justify-content:center;padding:.75rem}.sidebar.collapsed .sidebar-icon{margin-right:0}.sidebar.collapsed .sidebar-link.has-children:after{content:"";position:absolute;top:50%;right:8px;width:6px;height:6px;background-color:var(--color-primary, #007bff);border-radius:50%;transform:translateY(-50%)}.sidebar-debug-active{box-shadow:0 0 0 3px #ff000026 inset}.sidebar.mobile{width:280px;box-shadow:2px 0 8px #00000026}.sidebar.mobile.collapsed{transform:translate(-100%);width:280px}.sidebar.mobile:not(.collapsed){transform:translate(0)}.sidebar__nav::-webkit-scrollbar{width:4px}.sidebar__nav::-webkit-scrollbar-track{background:transparent}.sidebar__nav::-webkit-scrollbar-thumb{background-color:var(--color-border, #e0e0e0);border-radius:2px}.sidebar__nav::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-disabled, #999)}@media (max-width: 768px){.sidebar{width:280px;top:var(--header-height, 64px);height:calc(100vh - var(--header-height, 64px));transform:translate(-100%);box-shadow:2px 0 8px #00000026}.sidebar:not(.collapsed){transform:translate(0)}.sidebar.collapsed{transform:translate(-100%);width:280px}.sidebar__toggle{display:none}}@media (max-width: 480px){.sidebar{width:100vw;max-width:320px}.brand-text{font-size:1rem}.sidebar-link{padding:.875rem .75rem}.sidebar-label{font-size:.9375rem}}@media (prefers-contrast: high){.sidebar{border-right-width:2px}.sidebar-link:focus{outline-width:3px}.sidebar-link.active{border:2px solid var(--color-primary, #007bff)}}@media (prefers-reduced-motion: reduce){.sidebar,.sidebar-link,.sidebar-arrow,.sidebar-submenu,.sidebar-tooltip,.toggle-icon{transition:none}.sidebar-submenu.expanded{max-height:none}}.mobile-nav-backdrop{position:fixed;top:64px;left:0;right:0;bottom:0;background-color:#00000080;z-index:1998;opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{to{opacity:1}}.mobile-nav{position:fixed;top:64px;left:0;width:320px;max-width:85vw;height:calc(100vh - 64px);background-color:var(--color-surface, #ffffff);z-index:1999;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s ease;box-shadow:2px 0 12px #00000026;overflow:hidden}.mobile-nav.open{transform:translate(0)}.mobile-nav__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border, #e0e0e0);background-color:var(--color-primary, #007bff);color:#fff;min-height:64px}.mobile-nav__brand{display:flex;align-items:center;gap:.75rem}.brand-icon{font-size:1.5rem}.brand-text{font-weight:600;font-size:1.125rem}.mobile-nav__close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;color:#fff;transition:background-color .2s ease}.mobile-nav__close:hover{background:#fff3}.mobile-nav__close:focus{outline:2px solid white;outline-offset:2px}.close-icon{font-size:1.25rem;font-weight:700}.mobile-nav__user{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid var(--color-border, #e0e0e0);background-color:var(--color-background, #f8f9fa)}.user-avatar{width:56px;height:56px;border-radius:50%;background-color:var(--color-primary, #007bff);display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-initials{color:#fff;font-weight:600;font-size:1.25rem}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:1rem;color:var(--color-text-primary, #333);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.875rem;color:var(--color-text-secondary, #666);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--color-text-disabled, #999);text-transform:capitalize;background-color:var(--color-border, #e0e0e0);padding:.125rem .5rem;border-radius:12px;display:inline-block}.mobile-nav__menu{flex:1;overflow-y:auto;padding:.5rem 0}.mobile-menu-list{list-style:none;margin:0;padding:0}.mobile-menu-item{margin:0}.mobile-menu-link{display:flex;align-items:center;width:100%;padding:1rem 1.5rem;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .2s ease;position:relative}.mobile-menu-link:hover{background-color:var(--color-hover, rgba(0, 0, 0, .05))}.mobile-menu-link:focus{outline:none;background-color:var(--color-hover, rgba(0, 0, 0, .05))}.mobile-menu-link.active{background-color:var(--color-primary-light, rgba(0, 123, 255, .1));color:var(--color-primary, #007bff)}.mobile-menu-link.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary, #007bff)}.menu-icon{font-size:1.5rem;margin-right:1rem;flex-shrink:0;width:24px;text-align:center}.menu-label{flex:1;font-weight:500;font-size:1rem;color:var(--color-text-primary, #333);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-badge{background-color:var(--color-primary, #007bff);color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:12px;margin-left:.5rem;margin-right:.5rem;flex-shrink:0}.menu-arrow{font-size:1.25rem;color:var(--color-text-disabled, #999);flex-shrink:0}.mobile-nav__actions{padding:1rem 0;border-top:1px solid var(--color-border, #e0e0e0);border-bottom:1px solid var(--color-border, #e0e0e0)}.mobile-action-button{display:flex;align-items:center;width:100%;padding:.75rem 1.5rem;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .2s ease}.mobile-action-button:hover{background-color:var(--color-hover, rgba(0, 0, 0, .05))}.mobile-action-button:focus{outline:none;background-color:var(--color-hover, rgba(0, 0, 0, .05))}.action-icon{font-size:1.25rem;margin-right:1rem;flex-shrink:0;width:20px;text-align:center}.action-label{font-weight:500;font-size:.875rem;color:var(--color-text-primary, #333)}.mobile-nav__footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border, #e0e0e0);background-color:var(--color-background, #f8f9fa)}.mobile-logout-button{display:flex;align-items:center;width:100%;padding:.75rem 0;background:none;border:none;text-align:left;cursor:pointer;transition:color .2s ease;margin-bottom:1rem}.mobile-logout-button:hover{color:var(--color-error, #dc3545)}.mobile-logout-button:focus{outline:2px solid var(--color-error, #dc3545);outline-offset:2px;border-radius:4px}.logout-icon{font-size:1.25rem;margin-right:1rem;flex-shrink:0}.logout-label{font-weight:500;font-size:1rem;color:var(--color-error, #dc3545)}.app-version{text-align:center;font-size:.75rem;color:var(--color-text-disabled, #999);font-family:monospace}@media (hover: none) and (pointer: coarse){.mobile-menu-link,.mobile-action-button,.mobile-logout-button{min-height:48px}.mobile-nav__close{min-width:48px;min-height:48px}}.mobile-nav__menu::-webkit-scrollbar{width:4px}.mobile-nav__menu::-webkit-scrollbar-track{background:transparent}.mobile-nav__menu::-webkit-scrollbar-thumb{background-color:var(--color-border, #e0e0e0);border-radius:2px}.mobile-nav__menu::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-disabled, #999)}@media (max-width: 480px){.mobile-nav{width:100vw;max-width:none}.mobile-nav__header,.mobile-nav__user,.mobile-menu-link{padding:1rem}.mobile-action-button{padding:.75rem 1rem}.mobile-nav__footer{padding:1rem}}@media (prefers-contrast: high){.mobile-nav{border-right:2px solid var(--color-border, #e0e0e0)}.mobile-nav__header,.mobile-nav__user,.mobile-nav__actions,.mobile-nav__footer{border-bottom-width:2px;border-top-width:2px}.mobile-menu-link:focus,.mobile-action-button:focus,.mobile-logout-button:focus{outline-width:3px}}@media (prefers-reduced-motion: reduce){.mobile-nav,.mobile-nav-backdrop,.mobile-menu-link,.mobile-action-button,.mobile-logout-button,.mobile-nav__close{transition:none;animation:none}}.app-layout{--header-height: 64px;--sidebar-width: 240px;--sidebar-collapsed-width: 64px;height:100vh;width:100vw;display:flex;flex-direction:column;overflow:hidden;background:var(--color-background, #f5f5f5);font-family:system-ui,sans-serif}.app-header{height:var(--header-height);flex-shrink:0;z-index:1000}.app-layout__body{flex:1;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:#fff;border-right:1px solid var(--color-border, #e5e7eb);transition:width .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;height:calc(100vh - var(--header-height))}.app-layout.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width, 64px);flex-basis:var(--sidebar-collapsed-width, 64px)}.app-layout__main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;background:var(--color-background, #f9fafb);box-sizing:border-box;scrollbar-gutter:stable}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media (max-width: 1023px){.sidebar{position:fixed;top:var(--header-height);left:0;height:calc(100vh - var(--header-height));z-index:1100;transform:translate(-100%);box-shadow:4px 0 20px #00000026}.sidebar:not(.collapsed){transform:translate(0)}}.breadcrumb{margin:0;padding:0}.breadcrumb-list{display:flex;align-items:center;flex-wrap:wrap;list-style:none;margin:0;padding:0;gap:.5rem}.breadcrumb-item{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:var(--text-secondary, #6b7280)}.breadcrumb-item.active{color:var(--text-primary, #111827);font-weight:500}.breadcrumb-icon{font-size:.75rem;opacity:.7}.breadcrumb-link{color:inherit;text-decoration:none;transition:color .2s ease}.breadcrumb-link:hover{color:var(--primary-color, #3b82f6);text-decoration:underline}.breadcrumb-link:focus{outline:2px solid var(--primary-color, #3b82f6);outline-offset:2px;border-radius:2px}.breadcrumb-text{color:inherit}.breadcrumb-separator{color:var(--text-muted, #9ca3af);font-size:.75rem;margin:0 .25rem;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.breadcrumb-list{gap:.25rem}.breadcrumb-item{font-size:.8125rem}.breadcrumb-separator{margin:0 .125rem}.breadcrumb-item:not(:first-child):not(:last-child){display:none}.breadcrumb-item:first-child:not(:last-child):after{content:"...";margin-left:.5rem;color:var(--text-muted, #9ca3af)}}@media (prefers-contrast: high){.breadcrumb-link{text-decoration:underline}.breadcrumb-separator{font-weight:700}}@media (prefers-color-scheme: dark){.breadcrumb-item{color:#9ca3af}.breadcrumb-item.active{color:#f9fafb}.breadcrumb-link:hover{color:#60a5fa}.breadcrumb-separator{color:#6b7280}}.meter-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin:2px 0;border-radius:4px;cursor:pointer;transition:all .2s ease;position:relative}.meter-item:hover{background-color:#0000000d}.meter-item.selected{background-color:#2196f31a;border-left:3px solid #2196f3;padding-left:9px;box-shadow:inset 0 0 0 1px #2196f333}.meter-item-content{display:flex;align-items:center;flex:1;gap:8px;min-width:0}.expand-button{background:none;border:none;padding:0;cursor:pointer;font-size:12px;color:#666;transition:all .2s ease;width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:2px}.expand-button:hover{color:#333;background-color:#0000000d}.expand-button.expanded{transform:rotate(90deg)}.favorite-indicator{color:#ffc107;font-size:14px;flex-shrink:0;text-shadow:0 0 2px rgba(255,193,7,.3)}.meter-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;color:#333;font-weight:500}.favorite-button{background:none;border:none;padding:4px 8px;cursor:pointer;font-size:16px;color:#999;transition:all .2s ease;flex-shrink:0;border-radius:4px}.star-icon-container{display:inline-flex;align-items:center;justify-content:center}.star-icon-button{padding:4px!important;min-width:32px!important;min-height:32px!important;display:flex;align-items:center;justify-content:center;transition:all .2s ease-in-out}.star-icon-button:hover:not(:disabled){transform:scale(1.1)}.star-icon-button:disabled{opacity:.7}.star-icon-filled{color:#ffc107;font-size:24px}.star-icon-outlined{color:#9e9e9e;font-size:24px}.star-icon-loading{color:#1976d2!important}.meter-element-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;margin:2px 0 2px 24px;border-radius:4px;cursor:pointer;transition:all .2s ease;position:relative}.meter-element-item:hover{background-color:#0000000d}.meter-element-item.selected{background-color:#2196f31a;border-left:3px solid #2196f3;padding-left:9px;box-shadow:inset 0 0 0 1px #2196f333}.meter-element-content{display:flex;align-items:center;flex:1;gap:8px;min-width:0}.favorite-indicator{color:#ffc107;font-size:12px;flex-shrink:0;text-shadow:0 0 2px rgba(255,193,7,.3)}.element-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:#555}.favorite-button{background:none;border:none;padding:4px 8px;cursor:pointer;font-size:14px;color:#999;transition:all .2s ease;flex-shrink:0;border-radius:4px}.favorite-button:hover{color:#ffc107;background-color:#ffc1071a}.favorite-button.favorited{color:#ffc107}.meters-list{display:flex;flex-direction:column;gap:0;padding:8px 0;flex-shrink:0}.meters-header{display:flex;align-items:center;padding:8px 12px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;gap:8px}.meters-title{margin:0;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#333}.meters-list .empty-state{padding:16px 12px;text-align:center;color:#999;font-size:13px;font-style:italic}.meter-group{display:flex;flex-direction:column}.meter-elements{display:flex;flex-direction:column;gap:0;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.meter-elements .loading-elements{padding:8px 12px;margin-left:24px;color:#999;font-size:12px;font-style:italic}.meter-elements .no-elements{padding:8px 12px;margin-left:24px;color:#ccc;font-size:12px}.favorites-section{display:flex;flex-direction:column;gap:0;padding:12px 0;border-bottom:2px solid #e0e0e0;margin-bottom:8px;flex-shrink:0}.favorites-header{display:flex;align-items:center;padding:8px 12px;background-color:#f5f5f5;border-radius:4px;margin:0 8px}.favorites-title{margin:0;font-size:14px;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.favorites-list{display:flex;flex-direction:column;gap:0;padding:0}.favorites-empty-state{padding:12px;text-align:center;color:#999;font-size:12px;font-style:italic;margin:0 8px}.favorite-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;margin:2px 8px;border-radius:4px;cursor:pointer;transition:all .2s ease;position:relative}.favorite-item:hover{background-color:#0000000d}.favorite-item-content{display:flex;align-items:center;flex:1;gap:8px;min-width:0}.favorite-item-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:#555}.favorite-item-text:before{content:"★ ";color:#ffc107;margin-right:4px;font-size:12px}.sidebar-meters-section{display:flex;flex-direction:column;background-color:#fff}.sidebar-meters-section .loading-state{padding:16px 12px;text-align:center;color:#999;font-size:13px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.sidebar-meters-section .error-state{padding:12px;background-color:#ffebee;border:1px solid #ffcdd2;border-radius:4px;margin:8px}.sidebar-meters-section .error-message{color:#c62828;font-size:12px;margin-bottom:8px;line-height:1.4}.sidebar-meters-section .retry-button{background-color:#c62828;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;font-weight:500}.sidebar-meters-section .retry-button:hover{background-color:#b71c1c;box-shadow:0 2px 4px #0003}.sidebar-meters-section .retry-button:active{transform:scale(.98)}.landing-page{min-height:100vh;background:#f7f9fc;color:#0f172a}.landing-nav{position:sticky;top:0;z-index:10;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e2e8f0}.landing-nav-inner{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.landing-logo{display:flex;align-items:center;gap:12px;font-weight:700;font-size:1.1rem;color:#0f172a}.landing-logo img{width:44px;height:44px}.landing-nav-links{display:flex;align-items:center;gap:18px;font-weight:600;color:#334155}.landing-nav-links a,.landing-nav-links button{color:inherit;background:transparent;border:none;padding:8px 10px;font-size:.95rem;cursor:pointer}.landing-nav-links button:hover,.landing-nav-links a:hover{color:#0f62fe}.landing-dropdown{position:relative}.landing-dropdown-menu{position:absolute;top:42px;left:0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 12px 30px #0f172a1f;min-width:220px;padding:8px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s ease}.landing-dropdown:hover .landing-dropdown-menu,.landing-dropdown:focus-within .landing-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.landing-dropdown-menu a{display:block;padding:10px 12px;border-radius:8px;color:#1f2937;font-weight:500}.landing-dropdown-menu a:hover{background:#f1f5f9;color:#0f62fe}.landing-login{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;border:1px solid #cbd5f5;background:#eef2ff;color:#1e3a8a;font-weight:600}.landing-hero{max-width:1200px;margin:0 auto;padding:80px 24px 40px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px;align-items:center}.landing-hero h1{font-size:2.8rem;margin-bottom:16px;color:#0f172a}.landing-hero p{font-size:1.1rem;color:#475569;margin-bottom:24px}.landing-hero-actions{display:flex;flex-wrap:wrap;gap:12px}.landing-btn-primary,.landing-btn-secondary{padding:12px 20px;border-radius:10px;font-weight:600;border:none;cursor:pointer;text-decoration:none}.landing-btn-primary{background:#0f62fe;color:#fff}.landing-btn-secondary{background:#e2e8f0;color:#0f172a}.landing-hero-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 20px 50px #0f172a1f}.landing-hero-card ul{list-style:none;padding:0;margin:0;color:#1f2937}.landing-hero-card li{margin-bottom:12px;padding-left:24px;position:relative}.landing-hero-card li:before{content:"✓";position:absolute;left:0;color:#0f62fe;font-weight:700}.landing-section{max-width:1200px;margin:0 auto;padding:64px 24px}.landing-section h2{font-size:2rem;margin-bottom:16px}.landing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.landing-card{background:#fff;border-radius:16px;padding:20px;border:1px solid #e2e8f0}.landing-card h3{margin-bottom:8px;font-size:1.1rem}.landing-pricing{background:#0f172a;color:#fff;border-radius:24px;padding:32px}.landing-pricing h3{color:#fff}.landing-pricing p{color:#e2e8f0}.landing-footer{padding:32px 24px;text-align:center;color:#64748b}@media (max-width: 840px){.landing-nav-links{display:none}}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.dashboard-page{display:flex;flex-direction:column;height:100%;width:100%;background-color:#f5f5f5}.dashboard-page__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background-color:#fff;border-bottom:1px solid #e0e0e0;gap:1rem}.dashboard-page__title{margin:0;font-size:1.75rem;font-weight:600;color:#333}.dashboard-page__header-actions{display:flex;gap:.75rem;align-items:center}.dashboard-page__btn{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.dashboard-page__btn--primary:hover:not(:disabled){background-color:#1565c0;box-shadow:0 2px 8px #00000026}.dashboard-page__btn--secondary{background-color:#f5f5f5;color:#333;border:1px solid #ddd}.dashboard-page__btn--secondary:hover:not(:disabled){background-color:#eee;border-color:#999}.dashboard-page__error-banner{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#ffebee;border-bottom:1px solid #ef5350;color:#c62828;gap:1rem}.dashboard-page__error-banner p{margin:0;flex:1}.dashboard-page__error-close{background:none;border:none;color:#c62828;font-size:1.25rem;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;transition:color .2s ease}.dashboard-page__error-close:hover{color:#b71c1c}.dashboard-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem;padding:2rem}.dashboard-page__loading-spinner{width:40px;height:40px;border:4px solid #f5f5f5;border-top:4px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}.dashboard-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem;padding:2rem;text-align:center}.dashboard-page__empty-icon{font-size:3rem}.dashboard-page__empty-title{margin:0;font-size:1.5rem;font-weight:600;color:#333}.dashboard-page__empty-description{margin:0;color:#666;max-width:400px}.dashboard-page__cards-grid{flex:1;padding:1.5rem;overflow-y:auto}.dashboard-page__card-wrapper{background-color:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.dashboard-page__drag-handle{cursor:grab;color:#999;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s ease}.dashboard-page__drag-handle:hover{color:#666}.dashboard-page__drag-handle:active{cursor:grabbing}@media (max-width: 768px){.dashboard-page__header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-page__header-actions{width:100%;flex-wrap:wrap}.dashboard-page__btn{flex:1;min-width:120px}.dashboard-page__title{font-size:1.5rem}}.dashboard-card{position:relative}.dashboard-card__drag-handle{cursor:grab}.dashboard-card__drag-handle:active{cursor:grabbing}.dashboard-card .MuiCardContent-root{overflow:auto}.dashboard-card-modal__form{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.dashboard-card-modal__field-group{display:flex;flex-direction:column;gap:.5rem}.dashboard-card-modal__date-range-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.dashboard-card-modal__label{font-size:.875rem;font-weight:500;color:#333;display:flex;align-items:center;gap:.25rem}.dashboard-card-modal__required{color:#d32f2f;font-weight:600}.dashboard-card-modal__input,.dashboard-card-modal__select,.dashboard-card-modal__textarea{padding:.75rem;border:1px solid #ccc;border-radius:4px;font-size:.875rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.dashboard-card-modal__input:focus,.dashboard-card-modal__select:focus,.dashboard-card-modal__textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.dashboard-card-modal__input:disabled,.dashboard-card-modal__select:disabled,.dashboard-card-modal__textarea:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.dashboard-card-modal__input--error,.dashboard-card-modal__select--error{border-color:#d32f2f}.dashboard-card-modal__input--error:focus,.dashboard-card-modal__select--error:focus{box-shadow:0 0 0 3px #d32f2f1a}.dashboard-card-modal__textarea{resize:vertical;min-height:80px}.dashboard-card-modal__checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;padding:.75rem;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;max-height:300px;overflow-y:auto}.dashboard-card-modal__checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.dashboard-card-modal__checkbox{width:18px;height:18px;cursor:pointer;accent-color:#1976d2}.dashboard-card-modal__checkbox:disabled{cursor:not-allowed;opacity:.5}.dashboard-card-modal__checkbox-text{color:#333}.dashboard-card-modal__loading-text,.dashboard-card-modal__empty-text{padding:1rem;text-align:center;color:#999;font-size:.875rem}.dashboard-card-modal__error{color:#d32f2f;font-size:.75rem;margin-top:.25rem}.dashboard-card-modal__actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.dashboard-card-modal__btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.dashboard-card-modal__btn:disabled{opacity:.6;cursor:not-allowed}.dashboard-card-modal__btn--cancel{background-color:#f5f5f5;color:#333;border:1px solid #ccc}.dashboard-card-modal__btn--cancel:hover:not(:disabled){background-color:#e0e0e0}.dashboard-card-modal__btn--submit{background-color:#1976d2;color:#fff}.dashboard-card-modal__btn--submit:hover:not(:disabled){background-color:#1565c0}@media (max-width: 768px){.dashboard-card-modal__date-range-group,.dashboard-card-modal__checkbox-group{grid-template-columns:1fr}.dashboard-card-modal__actions{flex-direction:column-reverse}.dashboard-card-modal__btn{width:100%}}.expanded-card-modal{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:1000}.expanded-card-modal__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#00000080;cursor:pointer}.expanded-card-modal__content{position:relative;background:#fff;border-radius:8px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;width:95%;height:95%;max-width:1400px;max-height:900px;padding:24px;overflow:hidden}.expanded-card-modal__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.expanded-card-modal__title-section{flex:1;min-width:0}.expanded-card-modal__title{margin:0;font-size:24px;font-weight:600;color:#333;word-break:break-word}.expanded-card-modal__description{margin:6px 0 0;font-size:14px;color:#666;word-break:break-word}.expanded-card-modal__close-btn{background:none;border:none;font-size:28px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:#666;flex-shrink:0}.expanded-card-modal__close-btn:hover{background-color:#f5f5f5;color:#333}.expanded-card-modal__metadata{display:flex;gap:16px;font-size:13px;color:#666;margin-bottom:16px;flex-wrap:wrap;align-items:center}.expanded-card-modal__time-frame,.expanded-card-modal__visualization{display:flex;align-items:center;gap:6px}.expanded-card-modal__refresh-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:#666}.expanded-card-modal__refresh-btn:hover:not(:disabled){background-color:#f5f5f5;color:#333}.expanded-card-modal__refresh-btn:disabled{opacity:.5;cursor:not-allowed}.expanded-card-modal__export-btn{padding:6px 12px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;white-space:nowrap}.expanded-card-modal__export-btn:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 4px #0003}.expanded-card-modal__export-btn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.expanded-card-modal__email-btn{padding:6px 12px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;white-space:nowrap}.expanded-card-modal__email-btn:hover:not(:disabled){background-color:#0b7dda;box-shadow:0 2px 4px #0003}.expanded-card-modal__email-btn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.expanded-card-modal__visualization-container{flex:1;display:flex;align-items:center;justify-content:center;background-color:#fafafa;border-radius:6px;padding:16px;overflow:auto;min-height:400px}.expanded-card-modal__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#666;font-size:14px}.expanded-card-modal__error{display:flex;align-items:center;justify-content:center;color:#d32f2f;font-size:14px;text-align:center;padding:16px}.expanded-card-modal__no-data,.expanded-card-modal__no-renderer{display:flex;align-items:center;justify-content:center;color:#999;font-size:14px}.expanded-card-modal__spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 1024px){.expanded-card-modal__content{width:98%;height:98%;max-width:100%;max-height:100%;padding:16px}.expanded-card-modal__title{font-size:20px}.expanded-card-modal__close-btn{font-size:24px}}@media (max-width: 768px){.expanded-card-modal__content{width:100%;height:100%;max-width:100%;max-height:100%;padding:12px;border-radius:0}.expanded-card-modal__title{font-size:18px}.expanded-card-modal__metadata{font-size:12px;gap:12px}.expanded-card-modal__visualization-container{min-height:300px;padding:12px}}.visualization-container{width:100%;height:100%;display:flex;flex-direction:column}.visualization-empty{display:flex;align-items:center;justify-content:center;width:100%;min-height:300px}.visualization-empty p{margin:0;color:#666;font-size:14px}.recharts-legend-item-text,.recharts-legend-icon{display:none!important}.dashboard-page{padding:24px;max-width:1400px;margin:0 auto}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{touch-action:none}.react-grid-item img{pointer-events:none}.react-grid-item.cssTransforms{transition-property:transform}.react-grid-item.resizing{transition:none;z-index:1}.react-grid-item.react-draggable-dragging{transition:none;z-index:3}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:#1976d2;opacity:.2;border-radius:8px;z-index:2;border:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.dashboard-page__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;gap:24px}.dashboard-page__title-section{flex:1}.dashboard-page__title{margin:0;font-size:32px;font-weight:700;color:#333}.dashboard-page__header-actions{display:flex;gap:12px;flex-shrink:0}.dashboard-page__btn{padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;white-space:nowrap}.dashboard-page__btn--primary{background-color:#1976d2;color:#fff}.dashboard-page__btn--primary:hover{background-color:#1565c0;box-shadow:0 2px 8px #1976d24d}.dashboard-page__btn--primary:active{background-color:#0d47a1}.dashboard-page__btn--secondary{background-color:#f5f5f5;color:#333;border:1px solid #e0e0e0}.dashboard-page__btn--secondary:hover{background-color:#eee;border-color:#bdbdbd}.dashboard-page__btn--secondary:active{background-color:#e0e0e0}.dashboard-page__btn:disabled{opacity:.6;cursor:not-allowed}.dashboard-page__spinner{display:inline-block;animation:spin 1s linear infinite}.dashboard-page__error-banner{background-color:#ffebee;border:1px solid #ef5350;border-radius:6px;padding:12px 16px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center;gap:12px}.dashboard-page__error-banner p{margin:0;color:#c62828;font-size:14px}.dashboard-page__error-close{background:none;border:none;color:#c62828;cursor:pointer;font-size:18px;padding:0;flex-shrink:0}.dashboard-page__error-close:hover{opacity:.7}.dashboard-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:#666}.dashboard-page__loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}.dashboard-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;text-align:center;color:#666}.dashboard-page__empty-icon{font-size:64px;opacity:.5}.dashboard-page__empty-title{margin:0;font-size:24px;font-weight:600;color:#333}.dashboard-page__empty-description{margin:0;font-size:16px;color:#666;max-width:400px}.dashboard-page__cards-grid{background-color:#fafafa;border-radius:8px;padding:16px;min-height:600px}.dashboard-page__card-wrapper{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;display:flex;flex-direction:column}.dashboard-page__card-wrapper>*{height:100%}.react-grid-layout{background-color:#fafafa;border-radius:8px}.react-grid-item{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s ease;width:500px!important;height:600px!important}.react-grid-item:hover{box-shadow:0 4px 12px #00000026}.react-grid-item.react-grid-placeholder{background-color:#1976d2;opacity:.2;border-radius:8px}.react-grid-item>.react-resizable-handle{background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkIFBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=);background-position:bottom right;padding:0 8px 8px 0;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;cursor:se-resize}@media (max-width: 1024px){.dashboard-page{padding:16px}.dashboard-page__header{flex-direction:column;margin-bottom:24px}.dashboard-page__header-actions{width:100%}.dashboard-page__btn{flex:1;justify-content:center}.dashboard-page__cards-grid{padding:12px}}@media (max-width: 768px){.dashboard-page{padding:12px}.dashboard-page__title{font-size:24px}.dashboard-page__header-actions{flex-direction:column}.dashboard-page__btn{width:100%}.dashboard-page__cards-grid{padding:8px}}@media (max-width: 480px){.dashboard-page{padding:8px}.dashboard-page__title{font-size:20px}.dashboard-page__empty-icon{font-size:48px}.dashboard-page__empty-title{font-size:18px}.dashboard-page__empty-description{font-size:14px}.dashboard-page__cards-grid{padding:4px}}.simple-grid-container{width:100%;overflow-x:auto;border:1px solid #e0e0e0;border-radius:4px;background:#fff}.simple-grid{width:100%;border-collapse:collapse;font-size:14px}.simple-grid thead{background-color:#f5f5f5;border-bottom:2px solid #e0e0e0}.simple-grid th{padding:12px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.simple-grid tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}.simple-grid tbody tr:hover{background-color:#f9f9f9}.simple-grid td{padding:12px;color:#666}.simple-grid-info{padding:12px;background-color:#f9f9f9;border-top:1px solid #e0e0e0;font-size:12px;color:#999;text-align:right}.simple-grid-loading,.simple-grid-empty,.simple-grid-error{padding:40px;text-align:center;color:#999;background:#fff;border:1px solid #e0e0e0;border-radius:4px}.simple-grid-error{color:#d32f2f;background-color:#ffebee}.meter-reading-export-buttons{display:flex;align-items:center;gap:8px}.meter-reading-export-buttons .MuiButton-root{padding:6px 16px;font-size:14px;font-weight:500;text-transform:none;border-radius:4px;transition:all .2s ease;border:1px solid #d0d0d0;color:#333;background-color:#f5f5f5}.meter-reading-export-buttons .MuiButton-outlined:hover{background-color:#e8e8e8;border-color:#999;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.meter-reading-export-buttons .MuiButton-outlined:active{transform:translateY(0);box-shadow:0 1px 2px #0000000d}.meter-reading-export-buttons .MuiButton-outlined:disabled{background-color:#f9f9f9;border-color:#e0e0e0;color:#bdbdbd;cursor:not-allowed;opacity:.6}.meter-reading-export-buttons .MuiButton-startIcon{margin-right:6px;display:flex;align-items:center;justify-content:center}.meter-reading-export-buttons .MuiCircularProgress-root{color:#1976d2}.meter-reading-export-buttons .MuiTooltip-tooltip{background-color:#333;color:#fff;font-size:12px;padding:8px 12px;border-radius:4px;box-shadow:0 2px 8px #00000026}.meter-reading-export-buttons .MuiTooltip-arrow{color:#333}.meter-reading-export-buttons .MuiStack-root{display:flex;flex-direction:row;gap:8px;align-items:center}@media (max-width: 768px){.meter-reading-export-buttons{gap:6px}.meter-reading-export-buttons .MuiButton-root{padding:6px 12px;font-size:13px}@media (max-width: 480px){.meter-reading-export-buttons .MuiButton-root{padding:6px 8px;min-width:auto}.meter-reading-export-buttons .MuiButton-root .MuiButton-label{display:none}.meter-reading-export-buttons .MuiButton-startIcon{margin-right:0}}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.meter-reading-export-buttons .MuiCircularProgress-circle{animation:spin 1s linear infinite}.meter-reading-export-buttons .MuiButton-root:focus-visible{outline:3px solid #1976d2;outline-offset:2px;box-shadow:0 0 0 3px #1976d240}.meter-reading-export-buttons .MuiButton-root:disabled:focus-visible{outline:3px solid #bdbdbd;outline-offset:2px}.meter-reading-export-buttons .MuiButton-root:focus{outline:3px solid #1976d2;outline-offset:2px}@media (prefers-contrast: more){.meter-reading-export-buttons .MuiButton-outlined{border-width:2px}.meter-reading-export-buttons .MuiButton-outlined:hover{border-color:#333}.meter-reading-export-buttons .MuiButton-root:focus-visible{outline-width:4px;outline-color:#000}.meter-reading-export-buttons .MuiButton-root:disabled:focus-visible{outline-color:#666}}@media (prefers-reduced-motion: reduce){.meter-reading-export-buttons .MuiButton-root,.meter-reading-export-buttons .MuiButton-root:hover,.meter-reading-export-buttons .MuiButton-root:active{transition:none;transform:none}.meter-reading-export-buttons .MuiCircularProgress-circle{animation:none}.meter-reading-export-buttons .MuiButton-root:focus-visible{outline:3px solid #1976d2;outline-offset:2px}}@media (prefers-color-scheme: dark){.meter-reading-export-buttons .MuiButton-root{border-color:#555;color:#e0e0e0;background-color:#2a2a2a}.meter-reading-export-buttons .MuiButton-outlined:hover{background-color:#3a3a3a;border-color:#777}.meter-reading-export-buttons .MuiButton-outlined:disabled{background-color:#1a1a1a;border-color:#444;color:#666}.meter-reading-export-buttons .MuiTooltip-tooltip{background-color:#e0e0e0;color:#333}.meter-reading-export-buttons .MuiTooltip-arrow{color:#e0e0e0}}.meter-reading-export-buttons .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (pointer: coarse){.meter-reading-export-buttons .MuiButton-root{min-height:44px;min-width:44px;padding:10px 16px}}.meter-reading-export-buttons .MuiButton-root{font-size:14px;line-height:1.5}.meter-reading-export-buttons .MuiButton-root:disabled{opacity:.6;cursor:not-allowed}.meter-reading-export-buttons .MuiTooltip-tooltip{font-size:12px;line-height:1.4;max-width:300px}.meter-reading-export-buttons[role=group]{display:flex;align-items:center}.meter-reading-export-buttons .MuiCircularProgress-root[aria-label]{display:inline-flex}.meter-reading-export-buttons .MuiButton-root{position:relative}.meter-reading-export-buttons .MuiButton-root:focus-visible:after{content:"";position:absolute;top:-4px;left:-4px;right:-4px;bottom:-4px;border:2px solid transparent;border-radius:6px;pointer-events:none}.meter-reading-list{padding:20px;background:#fff;border-radius:4px}.meter-reading-list__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.meter-reading-list__header h2{margin:0;font-size:20px;color:#333;flex:1}.meter-reading-list__header-controls{display:flex;align-items:center;gap:12px}.meter-reading-list__error{padding:16px;margin-bottom:20px;background-color:#ffebee;border:1px solid #ef5350;border-radius:4px;color:#c62828}.meter-reading-list__error p{margin:0 0 12px}.meter-reading-list__retry-btn{padding:8px 16px;background-color:#ef5350;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.meter-reading-list__retry-btn:hover{background-color:#e53935}.meter-reading-list__switch-btn{padding:8px 16px;background-color:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.meter-reading-list__switch-btn:hover{background-color:#1565c0}.meter-reading-list__baselist-placeholder{padding:40px 20px;text-align:center;color:#999;background-color:#f5f5f5;border-radius:4px;border:1px dashed #ddd}.meter-reading-form{display:flex;flex-direction:column;gap:2rem;padding:1.5rem;background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.meter-reading-form__header{display:flex;justify-content:space-between;align-items:center;gap:1rem;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.meter-reading-form__header h1{margin:0;font-size:1.875rem;font-weight:700;color:#1f2937}.meter-reading-form__content{display:flex;flex-direction:column;gap:2rem}.meter-reading-form__section{display:flex;flex-direction:column;gap:1rem}.meter-reading-form__section h2{margin:0;font-size:1.25rem;font-weight:600;color:#374151}.meter-reading-form--loading{display:flex;justify-content:center;align-items:center;min-height:400px}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#6b7280;font-size:1rem}.loading-spinner:before{content:"";display:inline-block;width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.meter-reading-form--error{display:flex;justify-content:center;align-items:center;min-height:400px}.error-message{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;text-align:center}.error-message p{margin:0;color:#991b1b;font-size:1rem}.meter-reading-form--empty{display:flex;justify-content:center;align-items:center;min-height:400px}.empty-message{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;text-align:center}.empty-message p{margin:0;color:#6b7280;font-size:1rem}@media (max-width: 768px){.meter-reading-form{padding:1rem;gap:1.5rem}.meter-reading-form__header{flex-direction:column;align-items:flex-start}.meter-reading-form__header h1{font-size:1.5rem}.meter-reading-form__content{gap:1.5rem}.meter-reading-form__section h2{font-size:1.125rem}}.btn{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#2563eb}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover{background-color:#4b5563}.meter-info-panel{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem}.meter-info-panel__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.meter-info-panel__item{display:flex;flex-direction:column;gap:.5rem}.meter-info-panel__label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0}.meter-info-panel__value{font-size:1rem;font-weight:500;color:#1f2937;margin:0;word-break:break-word}.meter-info-panel__value:empty:before{content:"N/A";color:#9ca3af;font-style:italic}@media (max-width: 768px){.meter-info-panel{padding:1rem;gap:.75rem}.meter-info-panel__grid{grid-template-columns:1fr;gap:1rem}.meter-info-panel__label{font-size:.8125rem}.meter-info-panel__value{font-size:.9375rem}}@media (prefers-color-scheme: dark){.meter-info-panel{background-color:#1f2937;border-color:#374151}.meter-info-panel__label{color:#9ca3af}.meter-info-panel__value{color:#f3f4f6}}.reading-data-table{display:flex;flex-direction:column;gap:2rem}.reading-data-table__section{display:flex;flex-direction:column;gap:1rem}.reading-data-table__section-title{margin:0;font-size:1.125rem;font-weight:600;color:#374151;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.reading-data-table__table{width:100%;border-collapse:collapse;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.reading-data-table__header{padding:.75rem 1rem;background-color:#f3f4f6;border-bottom:2px solid #e5e7eb;text-align:left;font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.reading-data-table__header--metric{width:25%;min-width:150px}.reading-data-table__header--overall,.reading-data-table__header--phase{width:18.75%;min-width:120px}.reading-data-table__row{border-bottom:1px solid #e5e7eb;transition:background-color .2s ease}.reading-data-table__row:hover{background-color:#f9fafb}.reading-data-table__row:last-child{border-bottom:none}.reading-data-table__cell{padding:.75rem 1rem;font-size:.9375rem;color:#1f2937}.reading-data-table__cell--metric{font-weight:500;color:#374151;background-color:#f9fafb}.reading-data-table__cell--value{display:flex;align-items:center;gap:.5rem;justify-content:space-between}.reading-data-table__value{font-weight:500;color:#1f2937;font-family:Courier New,monospace;text-align:right;flex:1}.reading-data-table__unit{font-size:.8125rem;color:#6b7280;font-weight:400;min-width:2rem;text-align:left}.reading-data-table__value:has-text("—"){color:#9ca3af;font-style:italic}.reading-data-table__frequency{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;margin-top:1rem}.reading-data-table__frequency-item{display:flex;justify-content:space-between;align-items:center;gap:1rem}.reading-data-table__frequency-label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0}.reading-data-table__frequency-value{display:flex;align-items:center;gap:.5rem}.reading-data-table__frequency-value .reading-data-table__value{font-size:1.125rem;font-weight:600;color:#1f2937}.reading-data-table__frequency-value .reading-data-table__unit{font-size:.9375rem;color:#6b7280}.reading-data-table--empty{display:flex;justify-content:center;align-items:center;min-height:200px;padding:2rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem}.reading-data-table__empty-message{margin:0;color:#6b7280;font-size:1rem;text-align:center}@media (max-width: 1024px){.reading-data-table__header{padding:.625rem .75rem;font-size:.8125rem}.reading-data-table__cell{padding:.625rem .75rem;font-size:.875rem}.reading-data-table__header--metric{width:30%;min-width:120px}.reading-data-table__header--overall,.reading-data-table__header--phase{width:17.5%;min-width:100px}}@media (max-width: 768px){.reading-data-table{gap:1.5rem}.reading-data-table__section{gap:.75rem}.reading-data-table__section-title{font-size:1rem;padding-bottom:.375rem}.reading-data-table__table{font-size:.8125rem}.reading-data-table__header{padding:.5rem;font-size:.75rem}.reading-data-table__cell{padding:.5rem;font-size:.8125rem}.reading-data-table__cell--value{flex-direction:column;align-items:flex-end;gap:.25rem}.reading-data-table__value{text-align:right}.reading-data-table__unit{font-size:.75rem;min-width:auto;text-align:right}.reading-data-table__header--metric{width:35%;min-width:100px}.reading-data-table__header--overall,.reading-data-table__header--phase{width:21.67%;min-width:80px}.reading-data-table__frequency{padding:1rem;gap:.75rem}.reading-data-table__frequency-item{flex-direction:column;align-items:flex-start;gap:.5rem}.reading-data-table__frequency-value .reading-data-table__value{font-size:1rem}.reading-data-table__frequency-value .reading-data-table__unit{font-size:.875rem}}@media (max-width: 480px){.reading-data-table__header{padding:.375rem;font-size:.7rem}.reading-data-table__cell{padding:.375rem;font-size:.75rem}.reading-data-table__header--metric{width:40%;min-width:80px}.reading-data-table__header--overall,.reading-data-table__header--phase{width:20%;min-width:60px}}@media (prefers-color-scheme: dark){.reading-data-table__section-title{color:#e5e7eb;border-bottom-color:#374151}.reading-data-table__table{background-color:#1f2937;border-color:#374151}.reading-data-table__header{background-color:#111827;border-bottom-color:#374151;color:#9ca3af}.reading-data-table__row{border-bottom-color:#374151}.reading-data-table__row:hover{background-color:#111827}.reading-data-table__cell{color:#f3f4f6}.reading-data-table__cell--metric{color:#e5e7eb;background-color:#111827}.reading-data-table__value{color:#f3f4f6}.reading-data-table__unit{color:#9ca3af}.reading-data-table__frequency{background-color:#111827;border-color:#374151}.reading-data-table__frequency-label{color:#9ca3af}.reading-data-table__frequency-value .reading-data-table__value{color:#f3f4f6}.reading-data-table__frequency-value .reading-data-table__unit{color:#9ca3af}.reading-data-table--empty{background-color:#111827;border-color:#374151}.reading-data-table__empty-message{color:#9ca3af}}.form-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);padding:0;margin:0;flex-shrink:0;width:100%}.form-tabs__tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;color:var(--color-text-secondary, #6b7280);font-weight:500;cursor:pointer;transition:all .2s ease;font-size:16px;white-space:nowrap;outline:none;position:relative;border-radius:0}.form-tabs__tab:hover{color:var(--color-text-primary, #374151);background:#3b82f60d;border-radius:0}.form-tabs__tab:focus{outline:2px solid var(--color-primary, #3b82f6);outline-offset:-2px;border-radius:0}.form-tabs__tab--active{color:var(--color-text-primary, #1f2937);font-weight:600;border-bottom-color:#3b82f6;background:#3b82f60d;border-radius:0}@media (max-width: 768px){.form-tabs{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.form-tabs::-webkit-scrollbar{display:none}.form-tabs__tab{padding:.75rem 1rem;font-size:.875rem;flex-shrink:0}}.sidebar{flex:0 0 280px;min-width:280px;display:flex;flex-direction:column;gap:1rem;position:static;z-index:10}.sidebar__card{background-color:var(--color-surface, #ffffff);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;border:1px solid var(--color-border, #e5e7eb)}.sidebar__card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:var(--color-background, #f5f5f5);border-bottom:1px solid var(--color-border, #e0e0e0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.sidebar__card-header:hover{background-color:var(--color-border, #e0e0e0)}.sidebar__card-title{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-primary, #333333);text-transform:uppercase;letter-spacing:.5px}.sidebar__card-toggle{font-size:.75rem;color:var(--color-text-secondary, #666666);transition:transform .2s ease}.sidebar__card-content{padding:1rem}.sidebar__actions{display:flex;flex-direction:column;gap:.5rem}.sidebar__actions a,.sidebar__actions button{background:none;border:none;padding:.5rem 0;font-size:.875rem;font-weight:500;color:var(--color-primary, #007bff);cursor:pointer;text-align:left;text-decoration:none;transition:color .2s ease;display:flex;align-items:center;gap:.5rem}.sidebar__actions a:hover,.sidebar__actions button:hover{color:var(--color-primary-dark, #0056b3);text-decoration:underline}.sidebar__actions .material-symbols-outlined{font-size:1.25rem;vertical-align:middle}.sidebar__actions a[aria-disabled=true],.sidebar__actions button:disabled{color:var(--color-text-secondary, #9ca3af);cursor:not-allowed;text-decoration:none}.sidebar__actions a[aria-disabled=true]:hover,.sidebar__actions button:disabled:hover{color:var(--color-text-secondary, #9ca3af);text-decoration:none}.sidebar__stats{display:flex;flex-direction:column;gap:1rem}.sidebar__stat-item{padding-bottom:1rem;border-bottom:1px solid var(--color-border, #e5e7eb)}.sidebar__stat-item:last-child{border-bottom:none;padding-bottom:0}.sidebar__stat-label{font-size:.75rem;color:var(--color-text-secondary, #666666);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.sidebar__stat-value{font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #333333)}@media (max-width: 1024px){.sidebar{flex:1;min-width:auto;flex-direction:row}.sidebar__card{flex:1}}@media (max-width: 768px){.sidebar{flex-direction:column}.sidebar__card-header,.sidebar__card-content{padding:.75rem}.sidebar__actions a,.sidebar__actions button{padding:.375rem 0;font-size:.8125rem}}.base-form{display:flex;flex-direction:column;gap:0;padding:0;background:var(--color-background, #f9fafb);overflow:hidden;width:100%;min-width:0;margin:0 auto;height:100%;max-height:100vh}.base-form__content{display:flex;gap:1.5rem;padding:1rem;padding-top:0;width:100%;min-width:0;overflow-y:auto;flex:1;min-height:0}.base-form__main{flex:1;min-width:0;max-width:100%;width:100%;overflow-x:visible;overflow-y:visible}.base-form__sections-container{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;width:100%}.base-form__main--grid-1 .base-form__sections-container{grid-template-columns:1fr!important}.base-form__main--grid-2 .base-form__sections-container{grid-template-columns:repeat(2,1fr)!important}.base-form__main--grid-3 .base-form__sections-container{grid-template-columns:repeat(3,1fr)!important}.base-form__section--col-1{grid-column:1}.base-form__section--col-2{grid-column:2}.base-form__section--col-3{grid-column:3}.base-form__section--row-1{grid-row:1}.base-form__section--row-2{grid-row:2}.base-form__section--row-3{grid-row:3}.base-form__section--full-width{grid-column:1 / -1}.base-form__section{padding:1.25rem;background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:8px;box-shadow:0 1px 3px #0000000d;min-width:0;width:100%;display:block}.base-form__section:last-of-type{margin-bottom:0}.base-form__section-title{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--color-text-primary, #111827);display:flex;align-items:center;gap:.5rem}.base-form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.base-form__field{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem!important;position:relative}.base-form__section .base-form__field:last-child{margin-bottom:.5rem!important}.form-container .base-form__field{margin-bottom:1rem!important}.form-container .base-form__section .base-form__field:last-child{margin-bottom:.5rem!important}.base-form__field-wrapper{position:relative}.base-form .MuiTextField-root,.form-container .MuiTextField-root,.base-form .MuiFormControl-root,.form-container .MuiFormControl-root{margin-bottom:8px!important;margin-top:0!important}.base-form .MuiOutlinedInput-root,.form-container .MuiOutlinedInput-root{min-height:40px!important;margin:0!important}.base-form .MuiOutlinedInput-input,.form-container .MuiOutlinedInput-input{padding:8px 12px!important}.base-form .MuiFormHelperText-root,.form-container .MuiFormHelperText-root{margin-top:2px!important;margin-left:0!important;margin-right:0!important}.base-form input[type=date]::-webkit-calendar-picker-indicator,.form-container input[type=date]::-webkit-calendar-picker-indicator,.base-form input[type=time]::-webkit-calendar-picker-indicator,.form-container input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(.8);opacity:.7}.base-form input[type=date]::-webkit-calendar-picker-indicator:hover,.form-container input[type=date]::-webkit-calendar-picker-indicator:hover,.base-form input[type=time]::-webkit-calendar-picker-indicator:hover,.form-container input[type=time]::-webkit-calendar-picker-indicator:hover{opacity:1}.base-form .base-form__field,.form-container .base-form__field{margin-bottom:12px!important}div.base-form div.MuiTextField-root,div.form-container div.MuiTextField-root,div.base-form div.MuiFormControl-root,div.form-container div.MuiFormControl-root{margin-bottom:8px!important}.base-form .base-form__field+.base-form__field,.form-container .base-form__field+.base-form__field{margin-top:4px!important}.base-form .MuiInputBase-root,.form-container .MuiInputBase-root,.base-form .MuiInputLabel-root,.form-container .MuiInputLabel-root{margin:0!important}.base-form__label{position:absolute;top:.75rem;left:.75rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #6b7280);transition:all .2s cubic-bezier(.4,0,.2,1);transform-origin:left center;pointer-events:none;background-color:var(--color-surface, #ffffff);padding:0 .25rem;max-width:calc(100% - 1.5rem);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.base-form__label--error{color:var(--color-error, #dc2626);font-weight:600}.base-form__required{color:var(--color-error, #dc2626)}.base-form__error,.error-message,[role=alert]{color:var(--form-error-text, var(--color-error, #dc2626));font-size:.75rem;margin-top:.25rem}.help-text{color:var(--form-help-text, var(--color-text-secondary, #6b7280));font-size:.875rem;margin-top:.25rem}.base-form__actions{display:flex;flex-direction:column;gap:.75rem}.base-form__btn{padding:.75rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.base-form__btn--primary{background:var(--color-primary, #1976d2);color:#fff}.base-form__btn--primary:hover:not(:disabled){background:var(--color-primary-dark, #1565c0);box-shadow:0 2px 4px #1976d24d}.base-form__btn--secondary{background:var(--color-background-alt, #f3f4f6);color:var(--color-text-secondary, #6b7280);border:1px solid var(--color-border, #e5e7eb)}.base-form__btn--secondary:hover:not(:disabled){background:var(--color-background-hover, #e5e7eb);color:var(--color-text-primary, #111827);border-color:var(--color-border-hover, #d1d5db)}.base-form__btn:disabled{background:var(--color-background-alt, #f3f4f6);color:var(--color-text-secondary, #9ca3af);cursor:not-allowed;box-shadow:none}.base-form__spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:form-spin 1s linear infinite}@keyframes form-spin{to{transform:rotate(360deg)}}.form-error-toast{position:fixed;top:20px;right:20px;z-index:9999;animation:toast-slide-in .3s ease-out}@keyframes toast-slide-in{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.form-error-toast__content{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;background:var(--color-error, #dc2626);color:#fff;border-radius:6px;box-shadow:0 4px 12px #dc26264d;max-width:500px;min-width:300px}.form-error-toast__icon{font-size:1.25rem;flex-shrink:0}.form-error-toast__message{flex:1;font-size:.875rem;line-height:1.5}.form-error-toast__message strong{display:block;margin-bottom:.5rem;font-weight:600}.form-error-toast__details{margin-top:.5rem;padding:.5rem;background:#0003;border-radius:4px;font-family:monospace;font-size:.75rem;max-height:150px;overflow-y:auto}.form-error-toast__close{background:none;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:0;flex-shrink:0;opacity:.8;transition:opacity .2s ease}.form-error-toast__close:hover{opacity:1}.base-form__section:has(.base-form__field input:disabled){background:var(--color-background-alt, #f9fafb);border-color:var(--color-border, #e5e7eb);opacity:.85}.base-form__section:has(.base-form__field input:disabled) .base-form__section-title{color:var(--color-text-secondary, #6b7280);font-weight:500}@media (prefers-reduced-motion: reduce){.base-form__label,.base-form__input,.base-form__select,.base-form__textarea,input,select,textarea{transition:none}}@media (max-width: 1400px){.base-form__main--grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.base-form{flex-direction:column}.base-form__main--grid-2,.base-form__main--grid-3{grid-template-columns:1fr}.base-form__main{max-width:100%;width:100%}.base-form__sidebar{flex:1;min-width:auto;flex-direction:row}}@media (max-width: 768px){.base-form{padding:1.5rem;margin:1rem;flex-direction:column}.base-form__row{grid-template-columns:1fr;gap:1rem}.base-form__sidebar{flex-direction:column}}@media (max-width: 480px){.base-form{padding:1rem;margin:.5rem}.base-form__section-title{font-size:1.125rem}}.base-list__filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;padding:1rem;background-color:var(--color-surface, #ffffff);border-radius:8px;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.base-list__filters .list__filter-item{flex:0 0 auto;min-width:200px}.base-list__filters .list__filter-item .form-control{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border, #e0e0e0);border-radius:6px;background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #333333);font-size:.875rem;font-family:inherit;transition:all .2s ease}.base-list__filters .list__filter-item .form-control:focus{outline:none;border-color:var(--color-primary, #007bff);box-shadow:0 0 0 3px #007bff1a}.base-list__filters .list__filter-item .form-control::placeholder{color:var(--color-text-disabled, #999999)}.base-list__filters .list__filter-item select.form-control{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem}.base-list__filters .btn{padding:.5rem 1rem;border:1px solid var(--color-border, #e0e0e0);border-radius:6px;background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #333333);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.base-list__filters .btn:hover{background-color:var(--color-hover, rgba(0, 0, 0, .05));border-color:var(--color-primary, #007bff)}.base-list__filters .btn-secondary{background-color:var(--color-background, #f5f5f5);color:var(--color-text-secondary, #666666)}.base-list__filters .btn-secondary:hover{background-color:var(--color-border, #e0e0e0);color:var(--color-text-primary, #333333)}@media (max-width: 768px){.base-list__filters{flex-direction:column;align-items:stretch}.base-list__filters .list__filter-item{min-width:auto;width:100%}.base-list__filters .btn{width:100%;text-align:center}}@media (max-width: 480px){.base-list__filters{padding:.75rem;gap:.5rem}.base-list__filters .list__filter-item .form-control{font-size:.8125rem}}.list__main-content{display:flex;gap:.5rem;overflow:visible}.list__content{flex:1;min-width:0}.list__sidebar{flex:0 0 250px;min-width:250px;display:flex;flex-direction:column;gap:1rem}.list__sidebar-card{background-color:var(--color-surface, #ffffff);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.list__sidebar-card__header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:var(--color-background, #f5f5f5);border-bottom:1px solid var(--color-border, #e0e0e0);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.list__sidebar-card__header:hover{background-color:var(--color-border, #e0e0e0)}.list__sidebar-card__title{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-primary, #333333);text-transform:uppercase;letter-spacing:.5px}.list__sidebar-card__toggle{font-size:.75rem;color:var(--color-text-secondary, #666666)}.list__sidebar-card__content{padding:1rem}.list__header-actions{display:flex;flex-direction:column;gap:.5rem}.list__header-actions a,.list__header-actions button{background:none;border:none;padding:.5rem 0;font-size:.875rem;font-weight:500;color:var(--color-primary, #007bff);cursor:pointer;text-align:left;text-decoration:none;transition:color .2s ease;display:flex;align-items:center;gap:.5rem}.list__header-actions a:hover,.list__header-actions button:hover{color:var(--color-primary-dark, #0056b3);text-decoration:underline}.list__header-actions .material-symbols-outlined{font-size:1.25rem;vertical-align:middle}.list__stats{background-color:var(--color-surface, #ffffff);border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a}.list__stat-item{padding:.75rem 0;border-bottom:1px solid var(--color-border, #e0e0e0)}.list__stat-item:last-child{border-bottom:none}.list__stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.75rem;background-color:var(--color-background-primary);border-radius:.375rem;border:1px solid var(--color-border)}.list__stat-label{font-size:.75rem;color:var(--color-text-secondary, #666666);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.list__stat-value{font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #333333)}@media (max-width: 1024px){.list__main-content{flex-direction:column}.list__sidebar{flex:1;min-width:auto;flex-direction:row}.list__sidebar-card{flex:1}.list__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.list__stat-item{border-bottom:none;padding:0}}@media (max-width: 768px){.data-list__header{flex-direction:column;gap:1rem;align-items:stretch}.data-list__header-left{order:2;flex-direction:column}.data-list__title-section{order:1;text-align:left}.list__sidebar{flex-direction:column}.list__stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.data-list__header{padding:.75rem}.data-list__title{font-size:1.25rem}.list__stats{grid-template-columns:1fr}}.modal__backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:modal-fade-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal__backdrop--fullscreen{padding:0}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:90vh;position:relative;animation:modal-slide-up .3s ease-out}@keyframes modal-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal--sm{width:100%;max-width:400px}.modal--md{width:100%;max-width:90vw;min-width:600px}.modal--lg{width:100%;max-width:800px}.modal--xl{width:100%;max-width:1200px}.modal--fullscreen{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:0}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e0e0e0;flex-shrink:0;gap:1rem}.modal__title{margin:0;font-size:1.25rem;font-weight:600;color:#333;flex:1}.modal__header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.modal__save-btn{background-color:#2196f3;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.modal__save-btn:hover:not(:disabled){background-color:#1976d2}.modal__save-btn:disabled{opacity:.5;cursor:not-allowed}.modal__save-btn:focus{outline:2px solid #1565c0;outline-offset:2px}.modal__close{background:transparent;border:none;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#666;border-radius:4px;transition:background-color .2s,color .2s}.modal__close:hover:not(:disabled){background-color:#f5f5f5;color:#333}.modal__close:disabled{opacity:.5;cursor:not-allowed}.modal__close:focus{outline:2px solid #2196f3;outline-offset:2px}.modal__error{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background-color:#ffebee;border-left:4px solid #f44336;color:#c62828;flex-shrink:0}.modal__error-icon{font-size:1.25rem}.modal__error-message{flex:1}.modal__content{padding:0;overflow-y:auto;overflow-x:auto;flex:1}.modal__footer{padding:1rem 1.5rem;border-top:1px solid #e0e0e0;display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex-shrink:0}.modal__loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:10}.modal__loading-content{text-align:center}.modal__spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#2196f3;border-radius:50%;animation:modal-spinner-rotate .8s linear infinite;margin:0 auto 1rem}@keyframes modal-spinner-rotate{to{transform:rotate(360deg)}}@media (max-width: 768px){.modal__backdrop{padding:0}.modal{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:0}.modal__header{padding:1rem}.modal__content{padding:0}.modal__footer{padding:1rem}}.confirmation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100}.confirmation-modal{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:400px;width:90%;max-height:90vh;overflow:hidden}.confirmation-modal__header{padding:20px 24px 0}.confirmation-modal__title{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.confirmation-modal__body{padding:16px 24px}.confirmation-modal__message{margin:0;color:#6b7280;line-height:1.5}.confirmation-modal__footer{padding:16px 24px 24px;display:flex;gap:12px;justify-content:flex-end}.confirmation-modal__button{padding:8px 16px;border-radius:6px;border:1px solid transparent;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:80px}.confirmation-modal__button--cancel{background:#f9fafb;border-color:#d1d5db;color:#374151}.confirmation-modal__button--cancel:hover{background:#f3f4f6;border-color:#9ca3af}.confirmation-modal__button--confirm{color:#fff}.confirmation-modal__button--danger{background:#ef4444;border-color:#dc2626}.confirmation-modal__button--danger:hover{background:#dc2626;border-color:#b91c1c}.confirmation-modal__button--warning{background:#f59e0b;border-color:#d97706}.confirmation-modal__button--warning:hover{background:#d97706;border-color:#b45309}.confirmation-modal__button--info{background:#3b82f6;border-color:#2563eb}.confirmation-modal__button--info:hover{background:#2563eb;border-color:#1d4ed8}.entity-management-page{width:100%;height:100%;display:flex;flex-direction:column;background-color:var(--color-background, #f9fafb);min-height:100vh}.entity-list,.base-list{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem}.entity-list__header,.base-list__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;padding:0 .5rem}.entity-list__title,.base-list__title{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:var(--color-text-primary, #111827)}.entity-list__actions,.base-list__actions{display:flex;gap:.75rem;flex-wrap:wrap}.entity-list__btn,.base-list__btn{padding:.625rem 1.25rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.entity-list__btn--primary,.base-list__btn--primary{background-color:var(--color-primary, #1976d2);color:#fff}.entity-list__btn--primary:hover,.base-list__btn--primary:hover{background-color:var(--color-primary-dark, #1565c0);transform:translateY(-1px);box-shadow:0 4px 8px #1976d24d}.entity-list__btn--secondary,.base-list__btn--secondary{background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #111827);border:1px solid var(--color-border, #e5e7eb)}.entity-list__btn--secondary:hover,.base-list__btn--secondary:hover{background-color:var(--color-background-alt, #f3f4f6);border-color:var(--color-border-hover, #d1d5db)}.entity-list__filters{display:flex;flex-direction:row;flex-wrap:wrap;gap:1rem;padding:1.25rem;background-color:var(--color-surface, #ffffff);border-radius:8px;border:1px solid var(--color-border, #e5e7eb);align-items:center;box-shadow:0 1px 3px #0000000d}.entity-list__search,.base-list__search{flex:1;min-width:250px}.entity-list__search-input,.base-list__search-input{width:100%;padding:.75rem;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;font-size:.875rem;background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #111827);transition:border-color .2s ease,box-shadow .2s ease}.entity-list__search-input:focus,.base-list__search-input:focus{outline:none;border-color:var(--color-primary, #1976d2);box-shadow:0 0 0 3px #1976d21a}.entity-list__search-input::placeholder,.base-list__search-input::placeholder{color:var(--color-text-secondary, #6b7280)}.entity-list__filter-group,.base-list__filter-group{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.entity-list__filter-select,.base-list__filter-select{padding:.625rem .875rem;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;font-size:.875rem;background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #111827);cursor:pointer;min-width:140px;transition:border-color .2s ease}.entity-list__filter-select:focus,.base-list__filter-select:focus{outline:none;border-color:var(--color-primary, #1976d2);box-shadow:0 0 0 3px #1976d21a}.entity-list__clear-filters,.base-list__clear-filters{padding:.625rem .875rem;background-color:transparent;color:var(--color-text-secondary, #6b7280);border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s ease}.entity-list__clear-filters:hover,.base-list__clear-filters:hover{background-color:var(--color-background-alt, #f3f4f6);color:var(--color-text-primary, #111827)}@media (max-width: 1024px){.entity-list__filters,.base-list__filters{padding:1rem}}@media (max-width: 768px){.entity-list,.base-list{padding:1rem;gap:1rem}.entity-list__header,.base-list__header{flex-direction:column;align-items:stretch;padding:0}.entity-list__actions,.base-list__actions{justify-content:stretch}.entity-list__btn,.base-list__btn{flex:1;justify-content:center}.entity-list__filters,.base-list__filters{padding:.875rem}.entity-list__filter-group,.base-list__filter-group{flex-direction:column;align-items:stretch}.entity-list__filter-select,.base-list__filter-select,.entity-list__search,.base-list__search{min-width:auto}}@media (max-width: 480px){.entity-list,.base-list{padding:.75rem}.entity-list__title,.base-list__title{font-size:1.5rem}.entity-list__filters,.base-list__filters{padding:.75rem}}.user-list{display:flex;flex-direction:column}.user-list__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.user-list__title{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:var(--color-text-primary)}.user-list__btn{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.user-list__btn--primary{background-color:var(--color-primary);color:#fff}.user-list__btn--primary:hover{background-color:var(--color-primary-dark)}.user-list__btn--secondary{background-color:var(--color-background-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.user-list__btn--secondary:hover{background-color:var(--color-background-tertiary)}.user-list__export-content{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.user-list__export-info{font-size:.875rem;color:var(--color-text-secondary);margin:0}.user-list__export-count{padding:.75rem;background-color:var(--color-background-secondary);border-radius:.375rem;border:1px solid var(--color-border);margin:0;text-align:center}@media (max-width: 768px){.user-list{padding:.75rem;gap:1rem}.user-list__header{flex-direction:column;align-items:stretch}.user-list__btn{flex:1;justify-content:center}}@media (prefers-contrast: high){.user-list__role,.user-list__status{border:1px solid currentColor}.user-list__btn{border:2px solid currentColor}}@media (prefers-reduced-motion: reduce){.user-list__btn{transition:none}}.location-list__name-cell{display:flex;flex-direction:column;gap:.25rem}.location-list__name{font-weight:500;color:var(--color-text-primary, #111827)}.location-list__address{font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.location-list__type{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500;text-transform:capitalize}.location-list__type--office{background-color:var(--color-info-light);color:var(--color-info-dark)}.location-list__type--warehouse{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.location-list__type--retail{background-color:var(--color-success-light);color:var(--color-success-dark)}.location-list__type--residential{background-color:var(--color-primary-light);color:var(--color-primary-dark)}.location-list__type--industrial{background-color:var(--color-secondary-light);color:var(--color-secondary-dark)}.location-list__status{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.location-list__status--active{background-color:var(--color-success-light);color:var(--color-success-dark)}.location-list__status--inactive{background-color:var(--color-error-light);color:var(--color-error-dark)}.location-list__status--maintenance{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.location-list__location{display:flex;flex-direction:column;gap:.125rem}.location-list__zip{font-size:.75rem;color:var(--color-text-tertiary)}.location-list__count{font-size:.875rem;color:var(--color-text-secondary)}.location-list__export-content{padding:1rem 0}.location-list__export-content p{margin:0 0 1rem;color:var(--color-text-primary, #111827)}.location-list__export-info{font-size:.875rem;color:var(--color-text-secondary, #6b7280);background-color:var(--color-background-alt, #f3f4f6);padding:.75rem;border-radius:6px;border-left:3px solid var(--color-primary, #1976d2)}.location-list__export-count{font-weight:500;color:var(--color-primary, #1976d2)}.contact-form__tags-container{border:1px solid var(--color-border, #e5e7eb);border-radius:6px;padding:.5rem;background:var(--color-surface, #ffffff);min-height:2.5rem;transition:border-color .2s ease,box-shadow .2s ease}.contact-form__tags-container:focus-within{border-color:var(--color-primary, #1976d2);box-shadow:0 0 0 3px #1976d21a}.contact-form__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.contact-form__tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--color-primary, #1976d2);color:#fff;border-radius:4px;font-size:.75rem;font-weight:500}.contact-form__tag-remove{background:none;border:none;color:#fff;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.875rem;transition:background-color .2s ease}.contact-form__tag-remove:hover{background:#fff3}.contact-form__tag-remove:disabled{cursor:not-allowed;opacity:.5}.contact-form__tags-input{border:none;outline:none;font-size:.875rem;padding:.25rem;background:transparent;flex:1;min-width:200px}.contact-form__tags-input::placeholder{color:var(--color-text-secondary, #6b7280)}@media (max-width: 480px){.contact-form__tags-input{min-width:150px}}.contact-list{background:var(--color-surface, #ffffff);border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.contact-list__search{margin-bottom:1rem}.contact-list__search-input{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;font-size:1rem;transition:border-color .2s ease}.contact-list__search-input:focus{outline:none;border-color:var(--color-primary, #1976d2);box-shadow:0 0 0 3px #1976d21a}.contact-list__filter-group{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.contact-list__filter-select{padding:.5rem .75rem;border:1px solid var(--color-border, #e5e7eb);border-radius:4px;background:var(--color-surface, #ffffff);font-size:.875rem;min-width:140px;transition:border-color .2s ease}.contact-list__filter-select:focus{outline:none;border-color:var(--color-primary, #1976d2)}.contact-list__clear-filters{padding:.5rem 1rem;border:none;border-radius:4px;background:var(--color-background-alt, #f3f4f6);color:var(--color-text-secondary, #6b7280);font-size:.875rem;cursor:pointer;transition:all .2s ease}.contact-list__clear-filters:hover{background:var(--color-background-hover, #e5e7eb);color:var(--color-text-primary, #111827)}.contact-list__phone-link{color:var(--color-primary, #1976d2);text-decoration:none;transition:color .2s ease}.contact-list__phone-link:hover{color:var(--color-primary-dark, #1565c0);text-decoration:underline}.contact-list__location{font-size:.875rem}.contact-list__zip{color:var(--color-text-secondary, #6b7280);font-size:.75rem;margin-top:.125rem}.contact-list__tags{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.contact-list__no-tags{color:var(--color-text-secondary, #6b7280);font-size:.75rem;font-style:italic}.contact-list__more-tags{color:var(--color-text-secondary, #6b7280);font-size:.75rem;font-weight:500}.contact-list__btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.contact-list__btn--primary{background:var(--color-primary, #1976d2);color:#fff}.contact-list__btn--primary:hover{background:var(--color-primary-dark, #1565c0);transform:translateY(-1px);box-shadow:0 4px 8px #1976d24d}.contact-list__btn--secondary{background:var(--color-background-alt, #f3f4f6);color:var(--color-text-secondary, #6b7280);border:1px solid var(--color-border, #e5e7eb)}.contact-list__btn--secondary:hover{background:var(--color-background-hover, #e5e7eb);color:var(--color-text-primary, #111827);border-color:var(--color-border-hover, #d1d5db)}.contact-list__export-content{padding:1rem 0}.contact-list__export-info{color:var(--color-text-secondary, #6b7280);font-size:.875rem;margin:.75rem 0;line-height:1.5}.contact-list__export-count{font-weight:500;color:var(--color-text-primary, #111827);margin-top:1rem}@media (max-width: 768px){.contact-list__filter-group{flex-direction:column;align-items:stretch}.contact-list__filter-select{min-width:auto;width:100%}.contact-list__clear-filters{width:100%;text-align:center}}@media (max-width: 480px){.contact-list__search-input{font-size:.875rem}.contact-list__btn{width:100%;justify-content:center}}.editable-data-grid{display:flex;flex-direction:column;gap:16px;padding:16px}.editable-data-grid__header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.editable-data-grid__add-button{min-width:120px}.editable-data-grid__loading{margin-left:8px}.editable-data-grid__error{margin-bottom:8px}.editable-data-grid__table{border-radius:4px;box-shadow:0 2px 4px #0000001a}.editable-data-grid__header-cell{font-weight:600;background-color:#f5f5f5;border-bottom:2px solid #e0e0e0}.editable-data-grid__row{transition:background-color .2s ease;overflow:visible}.editable-data-grid__row:hover{background-color:#fafafa}.editable-data-grid__cell{padding:12px;cursor:pointer;transition:background-color .2s ease;position:relative;overflow:visible}.editable-data-grid__cell-content{display:flex;justify-content:space-between;align-items:center;width:100%}.editable-data-grid__cell-dropdown-icon{font-size:12px;color:#999;margin-left:8px}.editable-data-grid__cell--editable{cursor:pointer}.editable-data-grid__cell--editable:hover{background-color:#f0f0f0}.editable-data-grid__cell--editing{background-color:#fff3e0;padding:4px}.editable-data-grid__cell--editing-select{background-color:#fff!important}.editable-data-grid__input{width:100%}.editable-data-grid__input .MuiOutlinedInput-root{font-size:14px}.editable-data-grid__input .MuiOutlinedInput-root.Mui-focused{border-color:var(--form-focus-color, #0066cc);box-shadow:0 0 0 3px #0066cc1a}.editable-data-grid__select{width:100%}.editable-data-grid__select .MuiOutlinedInput-root{font-size:14px;background-color:#fff!important}.editable-data-grid__select .MuiOutlinedInput-input{color:#000!important;padding:8px 12px}.editable-data-grid__select .MuiOutlinedInput-root.Mui-focused{background-color:#fff!important;border-color:var(--form-focus-color, #0066cc);box-shadow:0 0 0 3px #0066cc1a}.editable-data-grid__select .MuiOutlinedInput-root.Mui-focused .MuiOutlinedInput-input{color:#000!important}.editable-data-grid__select .MuiSvgIcon-root{color:#666!important}.editable-data-grid__cell--editing .editable-data-grid__select .MuiSelect-select{color:#000!important;background-color:#fff!important}.editable-data-grid__cell--editing .editable-data-grid__select .MuiOutlinedInput-root{background-color:#fff!important}.editable-data-grid__cell--editing .editable-data-grid__select .MuiOutlinedInput-input{color:#000!important}.editable-data-grid__actions-cell{padding:8px;text-align:center}.editable-data-grid__delete-button{color:#d32f2f;transition:background-color .2s ease}.editable-data-grid__delete-button:hover{background-color:#d32f2f1a}.editable-data-grid__save-button{color:#4caf50;transition:background-color .2s ease}.editable-data-grid__save-button:hover{background-color:#4caf501a}.editable-data-grid__empty{padding:32px 16px;color:#999;font-style:italic}.editable-data-grid__row._unsaved{background-color:#fffbf0}.editable-data-grid__row._unsaved:hover{background-color:#fff9e6}.editable-data-grid__row._unsaved .editable-data-grid__cell{border-left:3px solid #ffc107}.registers-grid{width:100%;padding:16px}.registers-grid__header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.registers-grid__add-button{min-width:120px}.registers-grid__loading{margin-left:8px}.registers-grid__error{margin-bottom:16px}.registers-grid__table{border-radius:4px;box-shadow:0 2px 4px #0000001a}.registers-grid__row{transition:background-color .2s ease}.registers-grid__row:hover{background-color:#fafafa}.registers-grid__cell{padding:12px;cursor:pointer;transition:background-color .2s ease}.registers-grid__cell--editable:hover{background-color:#f0f0f0}.registers-grid__cell--editing{background-color:#fff3e0;padding:4px}.registers-grid__input{width:100%}.registers-grid__delete-button{color:#d32f2f;transition:background-color .2s ease}.registers-grid__delete-button:hover{background-color:#d32f2f1a}.registers-grid__empty{padding:32px 16px;color:#999;font-style:italic;text-align:center}.device-form-container{display:flex;flex-direction:column;height:100%}.device-form__tabs{border-bottom:1px solid #e0e0e0;margin-bottom:0}.device-form__content{flex:1;overflow-y:auto;padding:20px}.device-form{padding:0;max-width:100%;margin:0}.device-form__section{margin-bottom:24px}.device-form__section-title{font-size:18px;font-weight:600;margin-bottom:16px;color:#333;border-bottom:2px solid #1976d2;padding-bottom:8px}.device-form__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:16px}.device-form__field{margin-bottom:16px}.device-form__label{display:block;font-weight:600;margin-bottom:8px;color:#333;font-size:14px}.device-form__value{display:block;color:#666;font-size:14px;margin-bottom:16px}.device-form__required{color:#d32f2f}.device-form__btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;min-width:100px}.device-form__btn:disabled{opacity:.6;cursor:not-allowed}.device-form__btn--primary{background-color:#1976d2;color:#fff}.device-form__btn--primary:hover:not(:disabled){background-color:#1565c0;box-shadow:0 2px 4px #0003}.device-form__btn--secondary{background-color:#f5f5f5;color:#333}.device-form__btn--secondary:hover:not(:disabled){background-color:#e0e0e0}.device-form__field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.device-form__field-actions{display:flex;gap:8px}.btn-secondary{padding:8px 12px;background:#f5f5f5;color:#333;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;white-space:nowrap}.btn-secondary:hover:not(:disabled){background:#e0e0e0;border-color:#999}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.device-form--readonly{opacity:.9}.device-form--readonly .MuiInputBase-input{cursor:default}.device-form--readonly .MuiFormLabel-root{color:#0009!important}.registers-grid--readonly{opacity:.9}.registers-grid--readonly .MuiDataGrid-cell{cursor:default}.device-list--readonly .MuiTableCell-root{opacity:.9}.device-list{width:100%}.device-detail{padding:20px}.device-detail__section{margin-bottom:24px}.device-detail__section h3{font-size:18px;font-weight:600;margin-bottom:16px;color:#333}.device-detail__field{display:flex;padding:12px 0;border-bottom:1px solid #eee}.device-detail__field:last-child{border-bottom:none}.device-detail__field label{font-weight:600;min-width:120px;color:#666}.device-detail__field span{flex:1;color:#333}.form-container{display:flex;flex-direction:column;height:100%;background:var(--color-background, #f9fafb);overflow:hidden;margin:0;padding:0}.form-container__content{flex:1;overflow:auto;display:flex;min-height:0;padding:0;margin:0}.form-container .base-form{padding:.75rem 1.25rem 1.25rem;flex:1;height:100%;overflow:visible;margin:0}.form-container .MuiTextField-root,.form-container .MuiFormControl-root{margin-bottom:8px!important;margin-top:0!important}.form-container .base-form__field{margin-bottom:12px!important}.form-container .base-form__section .base-form__field:last-child{margin-bottom:8px!important}.form-container .base-form__section{padding:12px!important;margin-bottom:12px!important}.form-container .base-form__main{flex:1;min-height:0;overflow:visible}@media (max-width: 768px){.form-container .base-form{padding:.5rem 1rem 1rem}}.elements-grid{width:100%;display:flex;flex-direction:column;gap:16px}.dual-list-selector{display:flex;flex-direction:column;height:100%;background-color:var(--color-surface, #ffffff);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.dual-list-selector__wrapper{display:flex;gap:1rem;height:100%;padding:1rem;overflow:hidden}.dual-list-selector__column{display:flex;flex-direction:column;flex:1;min-width:0;background-color:var(--color-background, #f5f5f5);border-radius:6px;border:1px solid var(--color-border, #e0e0e0);overflow:hidden}.dual-list-selector__header{padding:.75rem 1rem;background-color:var(--color-primary, #007bff);color:var(--color-surface, #ffffff);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border, #e0e0e0);flex-shrink:0}.dual-list-selector__list-container{flex:1;overflow-y:auto;overflow-x:hidden;background-color:var(--color-surface, #ffffff);display:flex;flex-direction:column}.dual-list-selector__list{display:flex;flex-direction:column;gap:0}.dual-list-selector__item{padding:.75rem 1rem;border-bottom:1px solid var(--color-border, #e0e0e0);background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #333333);font-size:.875rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;outline:none;position:relative}.dual-list-selector__item:last-child{border-bottom:none}.dual-list-selector__item:hover{background-color:var(--color-hover, rgba(0, 123, 255, .08));color:var(--color-text-primary, #333333)}.dual-list-selector__item:focus,.dual-list-selector__item--focused{background-color:var(--color-primary-light, rgba(0, 123, 255, .15));color:var(--color-text-primary, #333333);box-shadow:inset 0 0 0 2px var(--color-primary, #007bff)}.dual-list-selector__item--dragging{opacity:.5;background-color:var(--color-primary-light, rgba(0, 123, 255, .1))}.dual-list-selector__empty-state{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem 1rem;color:var(--color-text-disabled, #999999);font-size:.875rem;text-align:center;background-color:var(--color-background, #f5f5f5)}.dual-list-selector__list-container::-webkit-scrollbar{width:8px}.dual-list-selector__list-container::-webkit-scrollbar-track{background:var(--color-background, #f5f5f5)}.dual-list-selector__list-container::-webkit-scrollbar-thumb{background:var(--color-border, #e0e0e0);border-radius:4px}.dual-list-selector__list-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary, #666666)}@media (max-width: 768px){.dual-list-selector__wrapper{flex-direction:column;gap:.75rem;padding:.75rem}.dual-list-selector__column{min-height:300px}.dual-list-selector__item,.dual-list-selector__header{padding:.625rem .75rem;font-size:.8125rem}}@media (max-width: 480px){.dual-list-selector__wrapper{padding:.5rem;gap:.5rem}.dual-list-selector__column{min-height:250px}.dual-list-selector__item,.dual-list-selector__header{padding:.5rem;font-size:.75rem}.dual-list-selector__empty-state{padding:1rem .5rem;font-size:.75rem}}@media (prefers-color-scheme: dark){.dual-list-selector{background-color:var(--color-surface-dark, #1e1e1e)}.dual-list-selector__column{background-color:var(--color-background-dark, #2d2d2d);border-color:var(--color-border-dark, #404040)}.dual-list-selector__list-container{background-color:var(--color-surface-dark, #1e1e1e)}.dual-list-selector__item{background-color:var(--color-surface-dark, #1e1e1e);color:var(--color-text-primary-dark, #e0e0e0);border-color:var(--color-border-dark, #404040)}.dual-list-selector__item:hover{background-color:var(--color-hover-dark, rgba(0, 123, 255, .15))}.dual-list-selector__item:focus,.dual-list-selector__item--focused{background-color:var(--color-primary-light-dark, rgba(0, 123, 255, .25))}.dual-list-selector__empty-state{background-color:var(--color-background-dark, #2d2d2d);color:var(--color-text-disabled-dark, #666666)}}.combined-meters-tab{display:flex;flex-direction:column;height:100%;padding:24px;background-color:#fafafa;font-family:Roboto,sans-serif}.combined-meters-tab__header{margin-bottom:24px}.combined-meters-tab__title{margin:0 0 8px;font-size:20px;font-weight:500;color:#212121;letter-spacing:.0125em}.combined-meters-tab__description{margin:0;font-size:14px;color:#666;line-height:1.5}.combined-meters-tab__search{margin-bottom:24px}.combined-meters-tab__search-input{width:100%;padding:12px 16px;font-size:14px;border:1px solid #e0e0e0;border-radius:4px;background-color:#fff;color:#212121;transition:all .2s ease;font-family:Roboto,sans-serif}.combined-meters-tab__search-input:hover{border-color:#bdbdbd;background-color:#fafafa}.combined-meters-tab__search-input:focus{outline:none;border-color:#1976d2;background-color:#fff;box-shadow:0 0 0 3px #1976d21a}.combined-meters-tab__search-input:disabled{background-color:#f5f5f5;color:#9e9e9e;cursor:not-allowed}.combined-meters-tab__selector{flex:1;position:relative;margin-bottom:16px;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden}.combined-meters-tab__saving-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;gap:12px}.combined-meters-tab__saving-overlay p{margin:0;font-size:14px;color:#666}.combined-meters-tab__meter-item{display:flex;flex-direction:column;gap:4px}.combined-meters-tab__meter-name{font-size:14px;font-weight:500;color:#212121}.combined-meters-tab__meter-identifier{font-size:12px;color:#999}.combined-meters-tab__footer{padding-top:12px;border-top:1px solid #e0e0e0}.combined-meters-tab__footer-text{margin:0;font-size:12px;color:#999}.combined-meters-tab--disabled{display:flex;align-items:center;justify-content:center;min-height:400px}.combined-meters-tab__disabled-message{text-align:center;padding:32px;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;max-width:400px}.combined-meters-tab__disabled-message p{margin:0 0 12px;font-size:14px;color:#666}.combined-meters-tab__disabled-message p:last-child{margin-bottom:0}.combined-meters-tab__disabled-hint{font-size:12px;color:#999}.combined-meters-tab--loading{display:flex;align-items:center;justify-content:center;min-height:400px}.combined-meters-tab__loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px}.combined-meters-tab__loading-spinner p{margin:0;font-size:14px;color:#666}.combined-meters-tab--error{display:flex;align-items:center;justify-content:center;min-height:400px}.combined-meters-tab__error-message{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px;background-color:#fff;border:1px solid #f44336;border-radius:4px;max-width:400px}.combined-meters-tab__error-text{margin:0;font-size:14px;color:#d32f2f;text-align:center}.combined-meters-tab__retry-button{padding:8px 16px;font-size:14px;font-weight:500;color:#fff;background-color:#1976d2;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;font-family:Roboto,sans-serif}.combined-meters-tab__retry-button:hover:not(:disabled){background-color:#1565c0;box-shadow:0 2px 4px #0000001a}.combined-meters-tab__retry-button:active:not(:disabled){background-color:#0d47a1}.combined-meters-tab__retry-button:disabled{background-color:#bdbdbd;cursor:not-allowed}.spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.combined-meters-tab{padding:16px}.combined-meters-tab__header{margin-bottom:16px}.combined-meters-tab__title{font-size:18px}.combined-meters-tab__description{font-size:13px}.combined-meters-tab__search{margin-bottom:16px}.combined-meters-tab__search-input{padding:10px 12px;font-size:13px}.combined-meters-tab__meter-name{font-size:13px}.combined-meters-tab__meter-identifier{font-size:11px}}.meter-form__elements-grid{width:100%;min-height:400px}.meter-list{width:100%}.meter-detail{padding:20px}.meter-detail__section{margin-bottom:24px}.meter-detail__section h3{font-size:18px;font-weight:600;margin-bottom:16px;color:#333}.meter-detail__field{display:flex;padding:12px 0;border-bottom:1px solid #eee}.meter-detail__field:last-child{border-bottom:none}.meter-detail__field label{font-weight:600;min-width:120px;color:#666}.meter-detail__field span{flex:1;color:#333}.form-field{margin-bottom:16px}.form-field label{display:block;font-weight:600;margin-bottom:8px;color:#333}.form-field input,.form-field textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:#1976d2}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #eee}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary{background-color:#1976d2;color:#fff}.btn-primary:hover{background-color:#1565c0}.btn-secondary{background-color:#f5f5f5;color:#333}.btn-secondary:hover{background-color:#e0e0e0}.meter-type-selector__title{font-size:1.5rem;font-weight:500;padding:24px 24px 16px}.meter-type-selector__content{padding:16px 24px}.meter-type-selector__description{margin:0 0 24px;color:#0009;font-size:.95rem;line-height:1.5}.meter-type-selector__buttons{display:flex;gap:16px;flex-direction:column}.meter-type-selector__button{padding:12px 24px;font-size:1rem;font-weight:500;text-transform:none;border-radius:4px;transition:all .3s ease}.meter-type-selector__button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.meter-type-selector__button--physical{background-color:#1976d2}.meter-type-selector__button--physical:hover{background-color:#1565c0}.meter-type-selector__button--virtual{background-color:#388e3c}.meter-type-selector__button--virtual:hover{background-color:#2e7d32}.meter-type-selector__actions{padding:16px 24px;border-top:1px solid rgba(0,0,0,.12)}.form-section{margin-bottom:1.5rem;padding:1.5rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000000d}.form-section__header{margin-bottom:1.5rem}.form-section__title{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#111827;display:flex;align-items:center;gap:.5rem}.form-section__description{margin:.5rem 0 0;font-size:.875rem;color:#6b7280;line-height:1.5}@media (max-width: 768px){.form-section{padding:1rem}.form-section__header{margin-bottom:1rem;padding-bottom:.75rem}.form-section__title{font-size:1rem}}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.form-actions__btn{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;line-height:1.5;border-radius:.375rem;border:1px solid transparent;cursor:pointer;transition:all .15s ease-in-out;display:inline-flex;align-items:center;gap:.5rem}.form-actions__btn:disabled{opacity:.6;cursor:not-allowed}.form-actions__btn--primary{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.form-actions__btn--primary:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.form-actions__btn--primary:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}.form-actions__btn--secondary{color:#374151;background-color:#fff;border-color:#d1d5db}.form-actions__btn--secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.form-actions__btn--secondary:focus{outline:none;box-shadow:0 0 0 3px #9ca3af33}.form-actions__spinner{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:form-actions-spin .6s linear infinite}@keyframes form-actions-spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.form-actions{flex-direction:column-reverse;gap:.5rem}.form-actions__btn{width:100%;justify-content:center}}.settings-form__section-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:#111827}.settings-form__label{font-weight:500;margin-bottom:.5rem;color:#374151;font-size:.875rem}.settings-form__input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:4px;font-size:1rem;background-color:#fff!important;color:#111827!important;transition:border-color .2s ease}.settings-form__input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.settings-form__input::placeholder{color:#9ca3af}.settings-form__input:disabled{background-color:#f3f4f6!important;color:#6b7280!important;cursor:not-allowed}.settings-tabs .MuiTab-root{color:#222!important;font-weight:500;background:transparent}.settings-tabs .Mui-selected{color:#2563eb!important}body[data-theme=dark] .settings-tabs .MuiTab-root,.dark .settings-tabs .MuiTab-root{color:#e0e0e0!important;background:#222!important}body[data-theme=dark] .settings-tabs .Mui-selected,.dark .settings-tabs .Mui-selected{color:#90caf9!important}.settings-content{margin-top:1.5rem}.placeholder-page{padding:2rem}.unauthorized-page{padding:2rem;text-align:center}.coming-soon-page{padding:4rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;margin:1rem;box-shadow:0 4px 6px #0000001a}.coming-soon-page h2{color:#2c3e50;font-size:2.5rem;margin-bottom:1rem;font-weight:600}.coming-soon-page p{color:#6c757d;font-size:1.1rem;max-width:500px;line-height:1.6;margin-bottom:2rem}.coming-soon-page:before{content:"⚠️";font-size:4rem;margin-bottom:1rem;opacity:.7}@media (max-width: 768px){.coming-soon-page{padding:2rem 1rem;margin:.5rem}.coming-soon-page h2{font-size:2rem}.coming-soon-page p{font-size:1rem}}.meters-page{flex:1;display:flex;flex-direction:column;background-color:#f8fafc;min-height:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 2rem;background:#fff;border-bottom:1px solid #e5e7eb;margin-bottom:2rem}.page-header__content h1{margin:0 0 .5rem;color:#111827;font-size:1.875rem;font-weight:700}.page-header__content p{margin:0;color:#6b7280;font-size:.875rem}.page-header__actions{display:flex;gap:1rem}.page-content{flex:1}.meter-details{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.meter-details__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;background:#f9fafb}.meter-details__header h3{margin:0;color:#111827;font-size:1.5rem;font-weight:600}.meter-details__actions{display:flex;gap:.5rem}.meter-details__content{padding:2rem}.detail-section{margin-bottom:2rem}.detail-section:last-child{margin-bottom:0}.detail-section h4{margin:0 0 1rem;color:#374151;font-size:1.125rem;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item label{font-weight:500;color:#6b7280;font-size:.875rem}.detail-item span{color:#111827;font-size:.875rem}.meter-details .status-indicator{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500}.meter-details .status-dot{width:8px;height:8px;border-radius:50%}.meter-details .status-dot--active{background-color:#10b981}.meter-details .status-dot--inactive{background-color:#6b7280}.meter-details .status-dot--maintenance{background-color:#f59e0b}.meter-details .badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}.meter-details .badge--primary{background-color:#dbeafe;color:#1e40af}.meter-details .badge--warning{background-color:#fef3c7;color:#92400e}.meter-details .badge--info{background-color:#e0f2fe;color:#0369a1}.meter-details .badge--success{background-color:#d1fae5;color:#065f46}@media (max-width: 768px){.page-header{flex-direction:column;gap:1rem;align-items:stretch}.page-header__actions{justify-content:stretch}.page-header__actions .btn{flex:1}.page-content{padding:0 1rem}.meter-details__header{flex-direction:column;gap:1rem;align-items:stretch}.meter-details__actions{justify-content:stretch}.meter-details__actions .btn{flex:1}.meter-details__content{padding:1rem}.detail-grid{grid-template-columns:1fr}}.report-list{width:100%}.report-name{display:flex;align-items:center;gap:8px}.report-name__text{font-weight:500;color:var(--text-primary, #333)}.report-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.report-type-badge--meter_readings{background-color:#e3f2fd;color:#1976d2}.report-type-badge--usage_summary{background-color:#f3e5f5;color:#7b1fa2}.report-type-badge--daily_summary{background-color:#e8f5e9;color:#388e3c}.schedule-code{font-family:Courier New,monospace;font-size:.875rem;background-color:#f5f5f5;padding:2px 6px;border-radius:3px;color:#d32f2f}.recipients-list{position:relative}.recipient-count{display:inline-block;padding:4px 8px;background-color:#f5f5f5;border-radius:4px;font-size:.875rem;font-weight:500;color:var(--text-secondary, #666)}.recipients-tooltip{display:none;position:absolute;top:100%;left:0;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:8px;margin-top:4px;min-width:200px;box-shadow:0 2px 8px #0000001a;z-index:10}.recipients-list:hover .recipients-tooltip{display:block}.recipient-email{padding:4px 0;font-size:.875rem;color:var(--text-primary, #333);word-break:break-all}.recipient-email:not(:last-child){border-bottom:1px solid #eee;padding-bottom:4px;margin-bottom:4px}.no-recipients{color:var(--text-disabled, #999);font-style:italic}.status-cell{display:flex;justify-content:center}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge--active{background-color:#c8e6c9;color:#2e7d32}.status-badge--inactive{background-color:#ffccbc;color:#d84315}.date-text{font-size:.875rem;color:var(--text-secondary, #666)}.recipients-field{display:flex;flex-direction:column;gap:12px}.recipients-input-group{display:flex;gap:8px;align-items:flex-start}.recipients-input-group .form-input{flex:1;min-width:0}.recipients-input-group .btn{flex-shrink:0;white-space:nowrap}.recipients-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.recipient-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;font-size:14px}.recipient-tag span{flex:1;word-break:break-word}.recipient-tag__remove{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:none;border:none;color:#666;cursor:pointer;font-size:18px;line-height:1;transition:color .2s}.recipient-tag__remove:disabled{cursor:not-allowed;opacity:.5}.form-error{display:block;color:#d32f2f;font-size:12px;margin-top:4px}.schedule-field{display:flex;flex-direction:column;gap:12px}.schedule-field__preset{display:flex;flex-direction:column;gap:6px}.schedule-field__preset .form-select{width:100%}.schedule-field__custom{display:flex;flex-direction:column;gap:6px}.schedule-field__custom .form-input{width:100%;font-family:Courier New,monospace;font-size:13px}.form-help{display:block;color:#666;font-size:12px;margin-top:4px;line-height:1.4}.form-error{display:block;color:#c62828;font-size:12px;margin-top:4px;font-weight:500}.form-select--error,.form-input--error{border-color:#c62828;background-color:#ffcdd2}.meter-element-selector{display:flex;flex-direction:column;gap:24px;padding:16px;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.selector-section{display:flex;flex-direction:column;gap:12px}.selector-section__title{margin:0;font-size:14px;font-weight:600;color:#1f2937;text-transform:uppercase;letter-spacing:.5px}.selector-section__loading,.selector-section__empty{padding:12px;font-size:13px;color:#6b7280;background-color:#f3f4f6;border-radius:4px;text-align:center}.selector-section__empty{font-style:italic}.meter-list,.element-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;padding:8px;background-color:#fff;border-radius:4px;border:1px solid #e5e7eb}.checkbox-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;border-radius:4px;transition:background-color .2s ease}.checkbox-item__input{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6;flex-shrink:0}.checkbox-item__label{font-size:13px;color:#374151;-webkit-user-select:none;user-select:none;flex:1;word-break:break-word}.meter-list::-webkit-scrollbar,.element-list::-webkit-scrollbar{width:6px}.meter-list::-webkit-scrollbar-track,.element-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.meter-list::-webkit-scrollbar-thumb,.element-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.meter-list::-webkit-scrollbar-thumb:hover,.element-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 768px){.meter-element-selector{padding:12px;gap:16px}.meter-list,.element-list{max-height:250px}.checkbox-item__label{font-size:12px}}.register-selector{display:flex;flex-direction:column;gap:12px;padding:16px;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.register-selector__loading,.register-selector__empty{padding:12px;font-size:13px;color:#6b7280;background-color:#f3f4f6;border-radius:4px;text-align:center}.register-selector__empty{font-style:italic}.register-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto;padding:8px;background-color:#fff;border-radius:4px;border:1px solid #e5e7eb}.checkbox-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;cursor:pointer;border-radius:4px;transition:background-color .2s ease}.checkbox-item:hover{background-color:#f3f4f6}.checkbox-item__input{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6;flex-shrink:0;margin-top:2px}.checkbox-item__input:disabled{cursor:not-allowed;opacity:.5}.checkbox-item__label{display:flex;flex-direction:column;gap:2px;flex:1;-webkit-user-select:none;user-select:none}.register-name{font-size:13px;font-weight:500;color:#374151}.register-unit{font-size:12px;color:#6b7280;font-weight:400}.register-description{font-size:12px;color:#9ca3af;font-style:italic;margin-top:2px}.checkbox-item:has(.checkbox-item__input:checked){background-color:#eff6ff;border-left:3px solid #3b82f6;padding-left:9px}.checkbox-item:has(.checkbox-item__input:disabled){opacity:.6;cursor:not-allowed}.form-error{display:block;padding:8px 12px;font-size:12px;color:#dc2626;background-color:#fee2e2;border-radius:4px;border-left:3px solid #dc2626}.register-list::-webkit-scrollbar{width:6px}.register-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.register-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.register-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 768px){.register-selector{padding:12px}.register-list{max-height:300px}.register-name{font-size:12px}.register-unit,.register-description{font-size:11px}}.report-form{display:flex;flex-direction:column;gap:24px;padding:24px;background-color:var(--surface, #fff)}.form-group{display:flex;flex-direction:column;gap:8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.form-label{font-weight:500;font-size:.875rem;color:var(--text-primary, #333);display:flex;align-items:center;gap:4px}.required{color:#d32f2f;font-weight:600}.form-input,.form-select{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:.875rem;font-family:inherit;transition:all .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.form-input--error,.form-select--error{border-color:#d32f2f}.form-input--error:focus,.form-select--error:focus{box-shadow:0 0 0 3px #d32f2f1a}.form-input:disabled,.form-select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-input--secondary{margin-top:8px}.form-help{font-size:.75rem;color:var(--text-secondary, #666);margin-top:4px}.form-error{font-size:.75rem;color:#d32f2f;margin-top:4px}.form-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#1976d2}.recipients-input-group{display:flex;gap:8px}.recipients-input-group .form-input{flex:1}.btn{padding:10px 16px;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background-color:#1976d2;color:#fff}.btn--primary:hover:not(:disabled){background-color:#1565c0;box-shadow:0 2px 8px #1976d24d}.btn--secondary:hover:not(:disabled){background-color:#eee;border-color:#bbb}.recipients-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.recipient-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background-color:#e3f2fd;border:1px solid #90caf9;border-radius:16px;font-size:.875rem;color:#1565c0}.recipient-tag__remove{background:none;border:none;color:#1565c0;cursor:pointer;font-size:1.25rem;line-height:1;padding:0;margin-left:4px;transition:color .2s ease}.recipient-tag__remove:hover:not(:disabled){color:#d32f2f}.recipient-tag__remove:disabled{cursor:not-allowed;opacity:.6}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid #eee}@media (max-width: 480px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}}.reports-page{width:100%;height:100%;display:flex;flex-direction:column}.page-content{flex:1;overflow:auto}.report-details{padding:24px;background-color:var(--surface, #fff)}.report-details__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #eee}.report-details__header h3{margin:0;font-size:1.5rem;color:var(--text-primary, #333)}.report-details__actions{display:flex;gap:8px}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn--secondary{background-color:#f5f5f5;color:var(--text-primary, #333);border:1px solid #ddd}.btn--secondary:hover{background-color:#eee;border-color:#bbb}.btn--sm{padding:6px 12px;font-size:.8125rem}.report-details__content{display:flex;flex-direction:column;gap:24px}.detail-section{display:flex;flex-direction:column;gap:12px}.detail-section h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary, #333);padding-bottom:8px;border-bottom:2px solid #f0f0f0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item--full{grid-column:1 / -1}.detail-item label{font-weight:500;font-size:.875rem;color:var(--text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.detail-item span{font-size:.9375rem;color:var(--text-primary, #333)}.badge{display:inline-block;padding:4px 12px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;width:fit-content}.badge--meter_readings{background-color:#e3f2fd;color:#1976d2}.badge--usage_summary{background-color:#f3e5f5;color:#7b1fa2}.badge--daily_summary{background-color:#e8f5e9;color:#388e3c}.status-indicator{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:500;width:fit-content}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.status-dot--active{background-color:#4caf50}.status-dot--inactive{background-color:#f44336}.schedule-code{display:inline-block;font-family:Courier New,monospace;font-size:.875rem;background-color:#f5f5f5;padding:8px 12px;border-radius:4px;color:#d32f2f;border:1px solid #e0e0e0}.recipients-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.recipient-item{padding:8px 12px;background-color:#f5f5f5;border-left:3px solid #1976d2;border-radius:2px;font-size:.875rem;color:var(--text-primary, #333)}.no-recipients{font-style:italic;color:var(--text-secondary, #666)}@media (max-width: 768px){.report-details{padding:16px}.report-details__header{flex-direction:column;align-items:flex-start;gap:12px}.report-details__actions{width:100%}.report-details__actions .btn{flex:1}.detail-grid{grid-template-columns:1fr}}.settings-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000a;padding:2rem;max-width:700px;margin:0 auto}.settings-form__section{margin-bottom:2rem}.settings-form__section-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.settings-form__row{display:flex;gap:2rem;margin-bottom:1rem}.settings-form__field{flex:1;display:flex;flex-direction:column}.settings-form__label{font-weight:500;margin-bottom:.5rem}.settings-form__input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:4px;font-size:1rem}.settings-form__actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.settings-form__btn{padding:.5rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.settings-form__btn--primary{background:#2563eb;color:#fff}.settings-form__btn--secondary{background:#f3f4f6;color:#111}.settings-form__error{color:#b91c1c;background:#fee2e2;border:1px solid #fca5a5;padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem}.meter-types-display{font-size:12px;margin:0;font-family:Courier New,Courier,monospace}#root{max-width:none;margin:0;padding:0;text-align:left}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
