@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--font-weight-medium:500;--font-weight-semibold:600;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.sticky{position:sticky}.flex{display:flex}.border{border-style:var(--tw-border-style);border-width:1px}}*{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#6366f1;--color-primary-hover:#7c3aed;--color-primary-pressed:#4f46e5;--color-brand:#8b4513;--color-brand-hover:sienna;--color-brand-light:peru;--color-accent:#fbbf24;--color-accent-hover:#f59e0b;--color-accent-light:#fcd34d;--color-sidebar-bg:#1e293b;--color-sidebar-active:#6366f1;--color-sidebar-active-hover:#7c3aed;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-xxl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--transition-fast:.15s ease;--transition-normal:.2s ease;--transition-slow:.3s ease}[data-theme=light]{--color-background:#f8f9fa;--color-surface:#fff;--color-surface-elevated:#fff;--color-surface-hover:#f1f3f5;--color-text-primary:#212529;--color-text-secondary:#495057;--color-text-tertiary:#6c757d;--color-text-disabled:#adb5bd;--color-border:#e9ecef;--color-border-light:#dee2e6;--color-border-dark:#ced4da;--shadow-sm:0 1px 2px #0000000d,0 1px 3px #0000001a;--shadow-md:0 2px 4px #0000000d,0 4px 8px #0000001a;--shadow-lg:0 4px 8px #0000000d,0 8px 16px #0000001a;--shadow-xl:0 8px 16px #0000000d,0 16px 32px #0000001a}[data-theme=dark]{--color-background:#0f172a;--color-surface:#1e293b;--color-surface-elevated:#334155;--color-surface-hover:#475569;--color-text-primary:#fff;--color-text-secondary:#cbd5e1;--color-text-tertiary:#94a3b8;--color-text-disabled:#64748b;--color-border:#334155;--color-border-light:#475569;--color-border-dark:#1e293b;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 2px 4px #0000004d;--shadow-lg:0 4px 8px #0006;--shadow-xl:0 8px 16px #00000080}html{font-size:14px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#212529;transition:background-color var(--transition-normal),color var(--transition-normal);background-color:#f8f9fa;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--color-surface);transition:background-color var(--transition-normal)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}::selection{background-color:var(--color-brand);color:#fff}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-hover)}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}.visually-hidden{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.btn-primary{padding:var(--spacing-sm)var(--spacing-md);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-base,14px);font-weight:var(--font-weight-medium,500);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);background-color:red;border:none}.btn-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.btn-secondary{padding:var(--spacing-sm)var(--spacing-md);background-color:var(--color-surface-elevated);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base,14px);font-weight:var(--font-weight-medium,500);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.btn-secondary:hover{background-color:var(--color-surface-hover);border-color:var(--color-accent)}.form-select{padding:var(--spacing-sm)var(--spacing-md);background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base,14px);cursor:pointer}.tab{padding:var(--spacing-sm)var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-base,14px);font-weight:var(--font-weight-medium,500);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000}.tab:hover{color:var(--color-text-primary)}.tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.table-container,.charts-container,.config-container,.mapping-container,.pid-container,.reports-container,.alerts-container,.settings-container,.users-container,.profile-container{margin-top:var(--spacing-lg)}.table-placeholder,.chart-placeholder{padding:var(--spacing-xxl);text-align:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-tertiary);justify-content:center;align-items:center;gap:var(--spacing-sm);flex-direction:column;min-height:300px;display:flex}.table-toolbar,.alerts-toolbar,.users-toolbar{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.toolbar-left,.toolbar-right{align-items:center;gap:var(--spacing-md);display:flex}.form-info{font-size:var(--font-size-sm,12px);color:var(--color-text-tertiary);font-style:italic}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}.app-header{height:65px;background-color:#fff;border-bottom:1px solid #e9ecef;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);position:fixed;top:0;left:230px;right:0;z-index:var(--z-index-sticky, 1020);box-shadow:0 1px 3px #0000000d;transition:left var(--transition-normal)}.app-header.copilot-open{left:70px}.header-left{display:flex;align-items:center;gap:var(--spacing-md);flex:0 0 auto}.header-title{font-size:16px;color:#212529;margin:0;line-height:1}.header-filters{display:flex;align-items:center;gap:var(--spacing-md);margin-left:var(--spacing-sm)}.menu-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:0;color:#495057;transition:background-color var(--transition-fast);background:transparent;border:none}.menu-button:hover{background-color:#f8f9fa;color:#212529}.header-search{position:relative;display:flex;align-items:center;margin-left:var(--spacing-md)}.search-input{width:300px;height:40px;padding:0 16px 0 40px;border:1px solid #e9ecef;border-radius:0;background-color:#f8f9fa;color:#495057;font-size:14px;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:#6366f1;background-color:#fff;box-shadow:0 0 0 3px #6366f11a}.search-input::placeholder{color:#adb5bd}.header-filter-group{display:flex;align-items:center;min-width:140px}.filter-select-wrapper{position:relative;display:flex;align-items:center}.filter-select{width:100%;height:36px;padding:0 36px 0 14px;background-color:#fff;border:1px solid #e5e7eb;border-radius:0;color:#111827;font-size:14px;font-weight:400;cursor:pointer;appearance:none;transition:border-color var(--transition-fast)}.filter-select:focus{outline:none;border-color:#d1d5db}.filter-select:hover{border-color:#d1d5db}.filter-chevron{position:absolute;right:12px;pointer-events:none;color:#6b7280;top:50%;transform:translateY(-50%);width:16px;height:16px}.header-right{display:flex;align-items:center;gap:var(--spacing-xs);flex:0 0 auto}.header-icon-button{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:0;color:#495057;transition:all var(--transition-fast);background:transparent;border:none}.header-icon-button:hover{background-color:#f8f9fa;color:#212529}.header-icon-badge{position:relative}.badge{position:absolute;top:6px;right:6px;min-width:18px;height:18px;padding:0 5px;background-color:#dc3545;color:#fff;border-radius:9px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid #ffffff}.user-profile-wrapper{position:relative;margin-left:var(--spacing-md)}.user-profile{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:0;transition:background-color var(--transition-fast);position:relative}.user-profile:hover{background-color:#f8f9fa;border-radius:30px}.dropdown-chevron{color:#6c757d;transition:transform var(--transition-fast);margin-left:var(--spacing-xs);flex-shrink:0}.dropdown-chevron.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background-color:#fff;border:1px solid #e9ecef;border-radius:0;box-shadow:0 4px 16px #0000001f;z-index:1000;overflow:hidden;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-section{padding:var(--spacing-xs) 0}.dropdown-header{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);font-size:12px;font-weight:700;color:#212529;background-color:#f8f9fa}.dropdown-list{max-height:200px;overflow-y:auto}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:14px;color:#212529;cursor:pointer;transition:all var(--transition-fast);min-width:0}.dropdown-item-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.dropdown-item:hover{background-color:#f8f9fa;color:#212529}.dropdown-item.active{background-color:#8b45131a;color:#8b4513;font-weight:500}.dropdown-item.active svg{color:#8b4513}.dropdown-item svg{color:#6c757d;flex-shrink:0}.dropdown-action{padding:var(--spacing-sm) var(--spacing-md)}.dropdown-action:hover svg{color:#212529}.dropdown-logout{color:#dc3545}.dropdown-logout:hover{background-color:#dc35451a;color:#dc3545}.dropdown-logout svg{color:#dc3545}.dropdown-divider{height:1px;background-color:#e9ecef;margin:var(--spacing-xs) 0}.user-avatar{width:32px;height:32px;border-radius:50%;background-color:#e9ecef;display:flex;align-items:center;justify-content:center;color:#6c757d;flex-shrink:0}.user-avatar svg{width:24px;height:24px}.user-info{display:flex;flex-direction:column;gap:2px}.user-name{font-size:14px;font-weight:600;color:#212529;line-height:1.2}.user-title{font-size:12px;color:#6c757d;line-height:1.2}@media(max-width:1024px){.app-header{left:0}.header-filters,.user-info{display:none}.user-profile-wrapper{margin-left:var(--spacing-sm)}.user-dropdown{right:0;min-width:220px}}@media(max-width:768px){.app-header{padding:0 var(--spacing-md);left:0}.header-right{gap:4px}.header-icon-button{width:32px;height:32px}.user-avatar{width:28px;height:28px}}.sidebar-overlay{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-index-modal-backdrop, 1040);display:none}@media(max-width:1024px){.sidebar-overlay{display:block}}.sidebar{width:230px;height:100vh;background:#0d1b26;border-right:0;display:flex;flex-direction:column;position:fixed;top:0;left:0;overflow-y:auto;overflow-x:hidden;z-index:var(--z-index-fixed, 1030);transition:width var(--transition-normal),transform var(--transition-normal)}.sidebar.collapsed{width:70px}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}}.sidebar-header{padding:var(--spacing-lg) var(--spacing-md);transition:padding var(--transition-normal)}.sidebar.collapsed .sidebar-header{padding:var(--spacing-lg) var(--spacing-sm);display:flex;justify-content:center}.sidebar-logo{display:flex;align-items:center;justify-content:center;width:100%}.logo-image{width:auto;height:60px;object-fit:contain}.logo-text{font-size:22px;font-weight:600;letter-spacing:-.3px;color:#fff}.sidebar-content{flex:1;padding:var(--spacing-md) 0;overflow-y:auto;overflow-x:visible}.sidebar.collapsed .sidebar-content{padding:var(--spacing-sm) 0}.sidebar-section{margin-bottom:var(--spacing-lg)}.sidebar-section:last-child{margin-bottom:0}.sidebar-section-title{font-size:11px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm);padding:0 var(--spacing-md);transition:opacity var(--transition-normal)}.sidebar.collapsed .sidebar-section-title{opacity:0;height:0;margin:0;padding:0;overflow:hidden}.sidebar.collapsed .sidebar-section{margin-bottom:var(--spacing-md)}.sidebar-nav{display:flex;flex-direction:column;gap:0;padding:0}.sidebar.collapsed .sidebar-nav{gap:0;padding:0}.nav-item-wrapper{display:flex;flex-direction:column}.nav-item{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-md);margin:0;border-radius:0;color:#ffffffb3;font-size:14px;font-weight:400;text-align:left;transition:all var(--transition-fast);background:transparent;border:none;cursor:pointer;position:relative;justify-content:flex-start}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-md);gap:0;margin:0;height:48px;display:flex;align-items:center;box-sizing:border-box}.nav-label{transition:opacity var(--transition-normal)}.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}.nav-item:hover{background-color:#ffffff0f;color:#fffffff2}.nav-item-active{background-color:#9e3f13;color:#fff;font-weight:500;margin:0;padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.sidebar.collapsed .nav-item-active{padding:var(--spacing-md);height:48px;box-sizing:border-box}.nav-item-active:hover{background-color:#ce4e13;color:#fff}.nav-item-active:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:0;height:0;border-top:10px solid transparent;border-bottom:10px solid transparent;border-right:10px solid #f3f4f6;z-index:2}.sidebar.collapsed .nav-item-active:after{display:none}.nav-icon{flex-shrink:0;color:inherit;width:16px;height:16px}.nav-icon-large{width:20px;height:20px}.nav-chevron{margin-left:auto;display:flex;align-items:center;color:#ffffff80;transition:transform var(--transition-fast)}.nav-sub-items{display:flex;flex-direction:column;padding-left:var(--spacing-md);margin-top:4px}.nav-sub-item{width:100%;display:flex;align-items:center;gap:var(--spacing-sm);padding:8px var(--spacing-md);padding-left:calc(var(--spacing-md) + 24px);border-radius:0;color:#fff9;font-size:13px;font-weight:400;text-align:left;transition:all var(--transition-fast);background:transparent;border:none;cursor:pointer;position:relative}.nav-sub-item:hover{background-color:#ffffff0d;color:#ffffffe6}.nav-sub-item-active{background-color:#8b451326;color:#8b4513;font-weight:500}.nav-sub-item-active:hover{background-color:#8b451333;color:#8b4513}.nav-sub-item .nav-icon{width:14px;height:14px}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid rgba(255,255,255,.08);background-color:#0003}.sidebar-section-items{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-link{padding:var(--spacing-xs) var(--spacing-sm);color:#ffffffb3;font-size:var(--font-size-sm, 12px);border-radius:0;transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar-link:hover{background-color:#ffffff1a;color:#ffffffe6}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.ai-copilot{position:fixed;top:65px;right:0;width:0;height:calc(100vh - 65px);background-color:#fff;display:flex;flex-direction:column;overflow:hidden;z-index:var(--z-index-fixed, 1030)}.ai-copilot.open{width:320px}.copilot-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid #e9ecef;background-color:var(--color-surface)}.copilot-header-title{font-size:16px;font-weight:600;color:#212529;margin:0}.copilot-close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:none;color:#6c757d;cursor:pointer;border-radius:4px;transition:all var(--transition-fast);padding:0}.copilot-close-button:hover{background-color:#f8f9fa;color:#212529}.copilot-content{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.copilot-history{display:flex;flex-direction:column;gap:var(--spacing-md)}.history-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm) 0;border-radius:2px;width:100%}.history-item.user{align-items:flex-start;background-color:#edf0f3;padding:var(--spacing-sm);border-radius:var(--radius-sm)}.history-item.user .history-content{background-color:transparent;color:#212529;padding:0;border-radius:0;width:100%;font-size:14px;font-weight:500}.history-item.assistant{align-items:flex-start}.history-item.assistant .history-content{background-color:transparent;color:#212529;padding:0;border-radius:0;width:100%;font-size:14px;white-space:pre-wrap;line-height:1.6}.history-chart{margin-top:var(--spacing-xs);width:100%}.history-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-xs);padding:6px 12px;background-color:#0d1b26;color:#fff;text-decoration:none;border-radius:2px;font-size:12px;font-weight:500;transition:all var(--transition-fast);width:fit-content}.history-link:hover{background-color:#0f1f2e;color:#fff}.copilot-response{display:flex;flex-direction:column;gap:var(--spacing-md);padding:0;background-color:transparent;border-radius:0;width:100%}.response-summary{font-size:14px;color:#212529;line-height:1.6}.response-summary p{margin:0 0 var(--spacing-xs) 0}.response-summary p:last-child{margin-bottom:0}.response-chart{margin:var(--spacing-sm) 0}.chart-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background-color:#fff;border:1px dashed #e9ecef;border-radius:2px;color:#6c757d;font-size:13px}.response-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:#0d1b26;color:#fff;text-decoration:none;border-radius:2px;font-size:13px;font-weight:500;transition:all var(--transition-fast);width:fit-content}.response-link:hover{background-color:#0f1f2e;color:#fff}.copilot-loading{display:flex;justify-content:center;padding:var(--spacing-lg)}.loading-dots{display:flex;gap:6px}.loading-dots span{width:8px;height:8px;background-color:#0d1b26;border-radius:50%;animation:loading-bounce 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes loading-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.copilot-suggestions-dropdown{position:absolute;bottom:calc(100% + var(--spacing-xs));left:0;background-color:#fff;border:1px solid #e9ecef;border-radius:4px;box-shadow:0 4px 12px #0000001a;min-width:200px;max-width:280px;max-height:200px;overflow-y:auto;display:flex;flex-direction:column;z-index:10}.suggestion-item{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:13px;color:#495057;cursor:pointer;transition:all var(--transition-fast);background-color:transparent;border:none;border-radius:0}.suggestion-item:hover{background-color:#f8f9fa;color:#212529}.suggestion-item:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.suggestion-item:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px}.copilot-input-area{padding:var(--spacing-sm) var(--spacing-md);background-color:#edf0f3;position:relative;display:flex;flex-direction:column;gap:var(--spacing-xs);margin:var(--spacing-sm);border-radius:var(--radius-md)}.input-row-top{display:flex}.copilot-input{flex:1;border:none;background-color:transparent;font-size:13px;color:#212529;resize:none;max-height:80px;overflow-y:auto;font-family:inherit;line-height:1.4;padding:var(--spacing-xs)}.copilot-input:focus{outline:none}.copilot-input::placeholder{color:#6c757d}.input-row-bottom{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs)}.suggestions-dropdown-button{display:flex;align-items:center;gap:4px;padding:4px 8px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;font-size:12px;color:#6c757d;cursor:pointer;transition:all var(--transition-fast);height:24px}.suggestions-dropdown-button:hover{background-color:#e9ecef;border-color:#d1d5db;color:#495057}.suggestions-dropdown-button.active{background-color:#e9ecef;border-color:#d1d5db;color:#212529}.suggestions-dropdown-button svg{flex-shrink:0}.suggestions-dropdown-button svg:first-child{width:14px;height:14px}.suggestions-dropdown-button svg:last-child{width:12px;height:12px;margin-left:2px;transition:transform var(--transition-fast)}.suggestions-dropdown-button svg:last-child.open{transform:rotate(180deg)}.suggestions-dropdown-button span{font-size:12px;line-height:1}.voice-button,.send-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:transparent;border:none;color:#6c757d;cursor:pointer;border-radius:2px;transition:all var(--transition-fast);flex-shrink:0;padding:0}.voice-button:hover,.send-button:hover:not(:disabled){background-color:#e9ecef;color:#212529}.voice-button.listening{background-color:#dc3545;color:#fff;animation:pulse 1.5s infinite}.voice-button.listening:hover{background-color:#c82333}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-button:not(:disabled){background-color:#0d1b26;color:#fff}.send-button:not(:disabled):hover{background-color:#0f1f2e}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.copilot-content::-webkit-scrollbar{width:6px}.copilot-content::-webkit-scrollbar-track{background:transparent}.copilot-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.copilot-content::-webkit-scrollbar-thumb:hover{background:#0000004d}@media(max-width:768px){.ai-copilot{width:100%;max-width:320px}}.app-layout{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f9fa}.app-layout.auth-layout{background:linear-gradient(135deg,#f5f5f5,#e8e8e8);height:100vh;width:100vw;overflow:hidden;position:fixed;inset:0}.app-body{display:flex;flex:1;overflow:hidden;background-color:#f8f9fa;position:relative}.app-main{flex:1;margin-left:230px;margin-top:65px;margin-right:0;padding:var(--spacing-lg);overflow-y:auto;min-height:calc(100vh - 65px);background-color:#f3f4f6;transition:margin-left var(--transition-normal),margin-right var(--transition-normal);min-width:0}.app-main.copilot-open{margin-left:70px}.app-main.copilot-open{margin-right:320px}.app-main.auth-main{margin-left:0;padding:0;display:flex;align-items:center;justify-content:center;background-color:transparent;height:100vh;width:100vw;overflow:hidden;position:fixed;inset:0}@media(max-width:1024px){.app-main{margin-left:0;margin-top:65px}.app-header{left:0}}.login-container{height:100vh;width:100vw;display:flex;overflow:hidden;position:fixed;inset:0;margin:0;padding:0}body:has(.login-container){overflow:hidden;height:100vh;width:100vw}.login-left-panel{width:40%;min-width:480px;height:100vh;background-color:#fff;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);overflow:hidden}.login-content{width:100%;max-width:420px;max-height:100vh;overflow:hidden;display:flex;flex-direction:column}.login-logo-section{margin-bottom:var(--spacing-lg);flex-shrink:0}.login-logo{display:inline-flex;margin-bottom:var(--spacing-md)}.login-logo-image{height:72px;width:auto;object-fit:contain}.login-form-section{width:100%;flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.login-heading{font-size:32px;font-weight:600;color:#212529;margin:0 0 var(--spacing-sm) 0}.login-description{font-size:14px;color:#6c757d;margin:0 0 var(--spacing-lg) 0;line-height:1.5}.login-form{display:flex;flex-direction:column;flex:1;min-height:0}.form-group label{font-size:14px;font-weight:500;color:#212529}.form-group input{padding:12px 16px;background-color:#fffef0;border:1px solid #f0f0e8;border-radius:4px;color:#212529;font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.form-group input::placeholder{color:#adb5bd}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:-2px!important;margin-bottom:10px!important}.remember-me{display:flex;align-items:center;gap:var(--spacing-xs);font-size:14px;color:#495057;cursor:pointer}.remember-me input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#1e4d6b}.forgot-password-link{background:none;border:none;color:#495057;font-size:14px;cursor:pointer;padding:0;transition:color var(--transition-fast);text-decoration:none}.forgot-password-link:hover{color:#1e4d6b;text-decoration:underline}.login-button{width:100%;padding:12px 24px;background-color:#1e4d6b;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);margin-top:var(--spacing-sm);flex-shrink:0}.login-button:hover{background-color:#2a6b8f;transform:translateY(-1px)}.login-button:active{transform:translateY(0)}.login-signup{margin-top:var(--spacing-lg);text-align:center;flex-shrink:0}.login-signup p{font-size:14px;color:#6c757d;margin:0}.signup-link{background:none;border:none;color:#1e4d6b;font-size:14px;font-weight:600;cursor:pointer;padding:0;transition:color var(--transition-fast)}.signup-link:hover{color:#2a6b8f;text-decoration:underline}.login-right-panel{width:60%;height:100vh;background:linear-gradient(135deg,#0d1b26,#1e4d6b,#2a6b8f);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xxl);position:relative;overflow:hidden}.promo-content{position:relative;width:100%;max-width:500px;display:flex;flex-direction:column;align-items:center;text-align:center;z-index:2}.sparkle{position:absolute;font-size:24px;color:#fbbf24;opacity:.6;animation:sparkle 3s ease-in-out infinite}.sparkle-1{top:10%;left:15%;animation-delay:0s}.sparkle-2{top:20%;right:20%;animation-delay:.5s}.sparkle-3{top:50%;left:10%;animation-delay:1s}.sparkle-4{top:60%;right:15%;animation-delay:1.5s}.sparkle-5{top:80%;left:25%;animation-delay:2s}.sparkle-6{top:30%;right:30%;animation-delay:2.5s}@keyframes sparkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.8;transform:scale(1.2)}}.promo-icon-wrapper{position:relative;margin-bottom:var(--spacing-xxl)}.promo-icon{width:180px;height:180px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 20px 60px #fbbf244d;position:relative;z-index:1}.promo-badge{position:absolute;top:-10px;right:-10px;width:60px;height:60px;background:linear-gradient(135deg,#1e4d6b,#163d54);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;border:4px solid #ffffff;box-shadow:0 4px 12px #0003;z-index:2}.promo-notification-bubble{position:absolute;top:-15px;right:-10px;width:28px;height:28px;background-color:#ef4444;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;border:3px solid #ffffff;z-index:3}.promo-text{margin-bottom:var(--spacing-xxl)}.promo-heading{font-size:36px;font-weight:700;color:#fff;margin:0 0 var(--spacing-md) 0;line-height:1.2}.promo-description{font-size:16px;color:#ffffffe6;line-height:1.6;margin:0}.promo-dots{display:flex;gap:var(--spacing-sm);align-items:center;justify-content:center}.dot{width:10px;height:10px;border-radius:50%;background-color:#ffffff4d;cursor:pointer;transition:background-color var(--transition-fast)}.dot.active{background-color:#fff;width:12px;height:12px}@media(max-width:1024px){.login-container{flex-direction:column}.login-left-panel{width:100%;min-width:unset;padding:var(--spacing-xl)}.login-right-panel{width:100%;min-height:400px;padding:var(--spacing-xl)}.promo-icon{width:140px;height:140px}.promo-icon svg{width:80px;height:80px}.promo-heading{font-size:28px}}@media(max-width:768px){.login-left-panel{padding:var(--spacing-lg)}.login-right-panel{padding:var(--spacing-lg);min-height:300px}.promo-icon{width:120px;height:120px}.promo-icon svg{width:60px;height:60px}.promo-heading{font-size:24px}.promo-description{font-size:14px}}.date-range-picker{position:relative;width:100%}.date-range-picker-trigger{display:flex;align-items:center;gap:var(--spacing-sm);padding:20px 12px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;cursor:pointer;transition:all var(--transition-fast);height:40px;width:100%;box-sizing:border-box;line-height:1}.date-range-picker-trigger:hover{border-color:#d1d5db}.date-range-picker-trigger:focus-within{border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.date-range-picker-trigger svg{color:#6c757d;flex-shrink:0}.date-range-text{flex:1;font-size:14px;color:#212529;text-align:left}.date-range-chevron{color:#6c757d;transition:transform var(--transition-fast);flex-shrink:0}.date-range-chevron.open{transform:rotate(180deg)}.date-range-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;box-shadow:0 4px 12px #0000001a;z-index:1000;min-width:200px}.date-range-options{display:flex;flex-direction:column;padding:4px 0;max-height:300px;overflow-y:auto}.date-range-option{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;background-color:transparent;border:none;font-size:14px;color:#212529;cursor:pointer;transition:background-color var(--transition-fast)}.date-range-option:hover{background-color:#f8f9fa}.date-range-option.active{background-color:#1e4d6b;color:#fff}.custom-date-inputs{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md);min-width:300px}.custom-date-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.custom-date-group label{font-size:12px;font-weight:500;color:#495057;text-transform:uppercase;letter-spacing:.5px}.custom-date-input{padding:8px 12px;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#495057;background-color:#fff;width:100%}.custom-date-input:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.custom-date-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding-top:var(--spacing-xs);border-top:1px solid #e9ecef}.custom-date-cancel,.custom-date-apply{padding:8px 16px;border:none;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.custom-date-cancel{background-color:#f8f9fa;color:#495057}.custom-date-cancel:hover{background-color:#e9ecef}.custom-date-apply{background-color:#1e4d6b;color:#fff}.custom-date-apply:hover:not(:disabled){background-color:#2a6b8f}.custom-date-apply:disabled{opacity:.5;cursor:not-allowed}.dashboard-page{width:100%;max-width:1400px;margin:0 auto}.page-title{font-size:28px;font-weight:700;color:#111827;margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:14px;color:#6b7280;margin:0}.dashboard-filters{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);flex-wrap:wrap;background-color:#fff;padding:var(--spacing-lg);border-radius:0;box-shadow:0 1px 3px #0000000d}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-sm);min-width:300px;max-width:400px}.filter-group label{font-size:13px;font-weight:500;color:#212529;text-transform:uppercase;letter-spacing:.5px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.kpi-card{background-color:#fff;border:none;border-radius:0;padding:var(--spacing-lg);box-shadow:none;transition:none;position:relative}.kpi-card:hover{box-shadow:none;transform:none}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-md)}.kpi-icon-wrapper{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-menu{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#9ca3af;cursor:pointer;border-radius:0;transition:color var(--transition-fast),background-color var(--transition-fast);padding:0}.kpi-menu:hover{color:#6b7280;background-color:#f3f4f6}.kpi-title{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm);margin-top:0}.kpi-value{font-size:28px;font-weight:700;color:#111827;margin-bottom:var(--spacing-xs);line-height:1.2}.kpi-trend{font-size:13px;color:#6b7280;font-weight:400}.kpi-trend.positive{color:#10b981;display:flex;align-items:center;gap:4px}.kpi-trend.positive:before{content:"↑";font-size:12px}.charts-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.charts-header-actions{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.date-range-inline{display:flex;align-items:center}.date-range-inline .date-range-picker,.date-range-inline .date-range-picker-trigger{width:auto;min-width:300px}.charts-section-title{font-size:20px;font-weight:600;color:#212529;margin:0}.add-chart-wrapper{position:relative}.add-chart-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 16px;background-color:#0d1b26;color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);height:40px;box-sizing:border-box}.add-chart-button:hover{background-color:#0f1f2e}.chart-dropdown-chevron{color:#fff;transition:transform var(--transition-fast);margin-left:var(--spacing-xs)}.chart-dropdown-chevron.open{transform:rotate(180deg)}.chart-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;box-shadow:0 4px 12px #0000001a;z-index:100;overflow:hidden}.chart-dropdown-item{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;background-color:transparent;border:none;font-size:14px;color:#212529;cursor:pointer;transition:background-color var(--transition-fast)}.chart-dropdown-item:hover{background-color:#f8f9fa}.chart-dropdown-item:first-child{border-bottom:1px solid #e9ecef}.dashboard-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-lg)}.chart-card{background-color:#fff;border:none;border-radius:0;overflow:hidden;display:flex;flex-direction:column}.chart-header{padding:var(--spacing-lg);border-bottom:none}.chart-title{font-size:var(--font-size-lg, 18px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-primary)}.chart-action{padding:var(--spacing-xs) var(--spacing-md);background-color:var(--color-primary);color:#fff;border:none;border-radius:0;font-size:var(--font-size-sm, 12px);font-weight:var(--font-weight-medium, 500);cursor:pointer;transition:background-color var(--transition-fast)}.chart-action:hover{background-color:var(--color-primary-hover)}.chart-container{padding:var(--spacing-lg);min-height:350px;background-color:#fff}.chart-legend{display:flex;gap:var(--spacing-md);align-items:center}.legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:12px;color:var(--color-text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.chart-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:none;flex-wrap:wrap;gap:var(--spacing-md)}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.kpi-grid{grid-template-columns:1fr}.chart-legend{flex-wrap:wrap}.chart-container{padding:var(--spacing-md);min-height:300px}}.page-template{width:100%;max-width:1400px;margin:0 auto}.page-header{margin-bottom:var(--spacing-xl)}.page-title{font-size:28px;font-weight:700;color:#212529;margin:0 0 var(--spacing-xs) 0}.page-subtitle{font-size:14px;color:#6c757d;margin:0}.page-content{margin-top:0!important}.page-content .pid-page{margin-top:0}.placeholder-content{padding:var(--spacing-xxl);text-align:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:0;color:var(--color-text-tertiary)}.realtime-table-wrapper{overflow-x:auto;margin-top:var(--spacing-md);margin-bottom:var(--spacing-md)}.realtime-table{width:100%;border-collapse:collapse;font-size:14px;background-color:#fff}.realtime-table thead{position:sticky;top:0;z-index:10}.parameter-row{background-color:#f8f9fa;border-bottom:2px solid #e9ecef}.parameter-header{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-weight:600;color:#212529;font-size:14px;white-space:nowrap;transition:background-color var(--transition-fast)}.unit-row{border-bottom:1px solid #e9ecef}.unit-header{padding:var(--spacing-sm) var(--spacing-lg);text-align:left;font-weight:400;color:#6c757d;font-size:12px;font-style:italic;white-space:nowrap}.data-row{border-bottom:1px solid #e9ecef;transition:background-color var(--transition-fast)}.data-row:hover{background-color:#f8f9fa}.data-row:last-child{border-bottom:none}.timestamp-cell{padding:var(--spacing-md) var(--spacing-lg);color:#495057;font-weight:500;white-space:nowrap}.value-cell{padding:var(--spacing-md) var(--spacing-lg);color:#212529;font-weight:500;text-align:right;white-space:nowrap}.table-container{background-color:#fff;border-radius:0;padding:var(--spacing-lg);box-shadow:0 1px 3px #0000000d;width:100%;max-width:1400px;margin:0 auto}.realtime-tabs-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;border-bottom:1px solid #e9ecef;margin-bottom:var(--spacing-md);width:100%;max-width:1400px;margin-left:auto;margin-right:auto;display:flex;justify-content:space-between;align-items:center;padding-right:var(--spacing-xl);min-height:fit-content;height:auto}.realtime-tabs-container{display:flex;gap:0;flex:1;min-height:fit-content;height:auto}.realtime-tabs-actions{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e0 #f7fafc;min-height:fit-content;height:auto}.realtime-tabs-actions::-webkit-scrollbar{height:6px}.realtime-tabs-actions::-webkit-scrollbar-track{background:#f7fafc;border-radius:3px}.realtime-tabs-actions::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.realtime-tabs-actions::-webkit-scrollbar-thumb:hover{background:#a0aec0}.realtime-tabs-actions .form-group{margin-bottom:0;display:flex;flex-direction:column;gap:var(--spacing-xs);flex-shrink:0;min-width:fit-content}.realtime-tabs-actions .form-label{font-size:13px;font-weight:500;color:#212529;margin-bottom:0}.realtime-tabs-actions .form-group select{padding:8px 44px 8px 24px;flex-shrink:0}.realtime-tabs-actions .btn-primary{flex-shrink:0;white-space:nowrap}.realtime-tab{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;color:#6c757d;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;bottom:-1px}.realtime-tab:hover{color:#212529;background-color:#f8f9fa}.realtime-tab.active{color:#1e4d6b;border-bottom-color:#1e4d6b;background-color:transparent}.realtime-content-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;width:100%;max-width:1400px;margin:0 auto}.live-streaming-content{min-height:200px}.streaming-controls{display:flex;flex-direction:column;gap:var(--spacing-lg)}.table-view-content{display:flex;flex-direction:column}.table-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.toolbar-left,.toolbar-right{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.toolbar-left{display:none}.toolbar-controls{position:relative}.btn-secondary{display:flex;align-items:center;gap:var(--spacing-xs)}.btn-primary,.btn-secondary{padding:8px 16px;border-radius:2px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background-color:#0d1b26;color:#fff}.btn-primary:hover{background-color:#0f1f2e}.btn-secondary{background-color:#0d1b26;color:#fff;border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background-color:#0f1f2e;color:#fff}.form-select{padding:11px 16px;border:1px solid #e9ecef;border-radius:2px;font-size:14px;background-color:#fff;color:#495057;cursor:pointer}.form-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.table-placeholder{padding:var(--spacing-xxl);text-align:center;background-color:#f8f9fa;border:1px dashed #e9ecef;border-radius:0;color:#6c757d}.table-placeholder p{margin:0 0 var(--spacing-xs) 0;font-weight:500}.table-placeholder span{font-size:13px}.header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs)}.sort-button{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:transparent;border:none;color:#6c757d;cursor:pointer;padding:0;border-radius:2px;transition:all var(--transition-fast);opacity:0}.parameter-header:hover .sort-button{opacity:1}.sort-button:hover{background-color:#e9ecef;color:#212529}.delete-column-button{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:transparent;border:none;color:#dc2626;cursor:pointer;padding:0;border-radius:2px;transition:all var(--transition-fast);opacity:.7}.calculated-header:hover .delete-column-button{opacity:1}.delete-column-button:hover{background-color:#fee2e2;color:#dc2626}.table-controls-dropdown,.thresholds-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:280px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;box-shadow:0 4px 12px #0000001a;z-index:100;max-height:400px;overflow-y:auto}.controls-section{padding:var(--spacing-md)}.controls-title{font-size:13px;font-weight:600;color:#212529;margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.column-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.column-toggle-item{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;font-size:13px;color:#495057;transition:background-color var(--transition-fast);border-radius:2px}.column-toggle-item:hover{background-color:#f8f9fa}.column-toggle-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;flex-shrink:0}.thresholds-dropdown{min-width:320px}.thresholds-info{padding:var(--spacing-md)}.thresholds-info p{font-size:13px;color:#495057;margin:0 0 var(--spacing-md) 0}.threshold-legend{display:flex;flex-direction:column;gap:var(--spacing-xs)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:12px;color:#495057}.legend-color{width:20px;height:20px;border-radius:2px;border:1px solid #e9ecef;flex-shrink:0}.modal-content{background-color:#fff;border-radius:0;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 4px 20px #0000004d}.modal-header h3{font-size:20px;font-weight:600;color:#212529;margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:none;color:#6c757d;cursor:pointer;transition:all var(--transition-fast);border-radius:2px}.modal-body{padding:var(--spacing-lg)}.formula-modal-body{display:grid;grid-template-columns:1fr 300px;gap:var(--spacing-lg);padding:var(--spacing-lg)}.formula-form-section{display:flex;flex-direction:column}.formula-annotations-section{display:flex;flex-direction:column;border-left:1px solid #e9ecef;padding-left:var(--spacing-lg);max-height:500px;overflow-y:auto}.annotations-header{margin-bottom:var(--spacing-md)}.annotations-header h4{font-size:14px;font-weight:600;color:#212529;margin:0;text-transform:uppercase;letter-spacing:.5px}.annotations-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.annotation-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;transition:all var(--transition-fast)}.annotation-item:hover{background-color:#e9ecef;border-color:#d1d5db}.annotation-name{font-size:13px;font-weight:500;color:#212529;flex:1}.annotation-unit{font-size:11px;color:#6c757d;font-style:italic}.form-group label{display:block;font-size:14px;font-weight:500;color:#212529;margin-bottom:var(--spacing-xs)}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:8px 12px;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#495057;background-color:#fff;font-family:inherit}.form-group input[type=text]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group select{cursor:pointer;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='%236c757d' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form-group textarea{resize:vertical;min-height:80px}.formula-help{margin-top:var(--spacing-xs);padding:var(--spacing-sm);background-color:#f8f9fa;border-radius:2px;font-size:12px;color:#6c757d}.formula-help p{margin:var(--spacing-xs) 0}.formula-help p:first-child{margin-top:0}.formula-help p:last-child{margin-bottom:0}.modal-footer .btn-secondary:hover{background-color:#e9ecef;border-color:#d1d5db}@media(max-width:768px){.realtime-tabs-card{flex-direction:column;align-items:stretch;padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}.realtime-tabs-container{width:100%}.realtime-tab{width:100%;text-align:left;border-left:2px solid transparent;bottom:0}.realtime-tab.active{border-left-color:#1e4d6b;border-bottom-color:transparent}.realtime-tabs-actions{padding:var(--spacing-md) 0;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden}.realtime-tabs-actions .form-group{width:100%}.table-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{flex-wrap:wrap}.annotations-table{font-size:12px}.annotations-table th,.annotations-table td{padding:var(--spacing-sm)}.table-controls-dropdown,.thresholds-dropdown{right:auto;left:0;min-width:100%}}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background-color:#fff;border-top:1px solid #e9ecef;margin-top:var(--spacing-md)}.pagination-info{display:flex;align-items:center;gap:var(--spacing-md);color:#6c757d;font-size:14px}.pagination-select{padding:6px 10px;border:1px solid #e9ecef;border-radius:4px;font-size:14px;color:#212529;background-color:#fff;cursor:pointer;transition:all var(--transition-fast)}.pagination-select:hover{border-color:#1e4d6b}.pagination-select:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.pagination-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.pagination-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 12px;background-color:#fff;border:1px solid #e9ecef;border-radius:4px;font-size:14px;color:#495057;cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background-color:#f8f9fa;border-color:#d1d5db;color:#212529}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{display:flex;align-items:center;gap:var(--spacing-xs)}.pagination-number{min-width:36px;height:36px;padding:0 8px;background-color:#fff;border:1px solid #e9ecef;border-radius:4px;font-size:14px;color:#495057;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.pagination-number:hover{background-color:#f8f9fa;border-color:#d1d5db;color:#212529}.pagination-number.active{background-color:#1e4d6b;border-color:#1e4d6b;color:#fff}.pagination-number.active:hover{background-color:#2a6b8f;border-color:#2a6b8f}.pagination-ellipsis{padding:0 8px;color:#6c757d;font-size:14px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.pagination-container{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.pagination-info{justify-content:space-between;width:100%}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}.formula-modal-body{grid-template-columns:1fr;gap:var(--spacing-md)}.formula-annotations-section{border-left:none;border-top:1px solid #e9ecef;padding-left:0;padding-top:var(--spacing-lg);max-height:300px}.modal-content{max-width:95%}}.realtime-charts-page{width:100%;max-width:1400px;margin:0 auto}.charts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:var(--spacing-lg);align-items:start}.add-chart-card{grid-column:span 1;min-width:500px;width:100%}.chart-card{background-color:#fff;border:none;border-radius:0;display:flex;flex-direction:column;box-shadow:0 1px 3px #0000000d}.chart-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #e9ecef}.chart-card-title{font-size:16px;font-weight:600;color:#212529;margin:0}.chart-card-actions{display:flex;gap:var(--spacing-xs);align-items:center}.chart-control-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#495057;cursor:pointer;transition:all var(--transition-fast);padding:0}.chart-control-btn:hover:not(:disabled){background-color:#f8f9fa;color:#212529;border-color:#d1d5db}.chart-control-btn:disabled{opacity:.4;cursor:not-allowed}.chart-card-content{padding:var(--spacing-lg);min-height:350px}.chart-placeholder{display:flex;align-items:center;justify-content:center;height:300px;background-color:#f8f9fa;border:1px dashed #e9ecef;color:#6c757d;font-size:14px}.add-chart-card{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:415px;cursor:pointer;transition:all var(--transition-fast);border:2px dashed #e9ecef;background-color:#f8f9fa;padding:var(--spacing-lg);box-sizing:border-box}.add-chart-card:hover{border-color:#0d1b26;background-color:#f0f0f0;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.add-chart-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);text-align:center;color:#6c757d}.add-chart-content svg{color:#0d1b26;transition:transform var(--transition-fast)}.add-chart-card:hover .add-chart-content svg{transform:scale(1.1)}.add-chart-content h3{font-size:18px;font-weight:600;color:#212529;margin:0}.add-chart-content p{font-size:14px;color:#6c757d;margin:0}.modal-content{background-color:#fff;border-radius:0;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column}.modal-header h2{font-size:20px;font-weight:600;color:#212529;margin:0}.modal-close{background:none;border:none;cursor:pointer;color:#6c757d;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.modal-body{padding:var(--spacing-lg);flex:1;overflow-y:auto}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;font-size:14px;font-weight:500;color:#212529;margin-bottom:var(--spacing-sm)}.form-group input[type=text],.form-group select{width:100%;padding:8px 12px;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#495057;background-color:#fff}.form-group input[type=text]:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.annotations-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:14px;color:#495057;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid #e9ecef}.modal-footer .btn-primary,.modal-footer .btn-secondary{padding:8px 16px;border-radius:2px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast)}.modal-footer .btn-primary{background-color:#0d1b26;color:#fff}.modal-footer .btn-primary:hover{background-color:#0f1f2e}.modal-footer .btn-secondary{background-color:#f8f9fa;color:#495057;border:1px solid #e9ecef}.modal-footer .btn-secondary:hover{background-color:#e9ecef;color:#212529}@media(max-width:768px){.charts-grid{grid-template-columns:1fr}.chart-card-actions{flex-wrap:wrap}.modal-content{width:95%;max-height:95vh}.annotations-checkboxes{grid-template-columns:1fr}}.configuration-page{width:100%;max-width:1400px;margin:0 auto;display:flex;flex-direction:column}.config-header{margin-bottom:var(--spacing-sm);padding-bottom:0}.config-title{font-size:24px;font-weight:700;color:#212529;margin:0}.config-tabs-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;border-bottom:1px solid #e9ecef;margin-bottom:var(--spacing-md)}.config-tabs-container{display:flex;gap:0}.config-tab{padding:var(--spacing-md) 0;background:none;border:none;border-bottom:2px solid transparent;color:#6c757d;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;bottom:-1px}.config-content-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;padding:var(--spacing-xl)}.config-content{min-height:400px}.config-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);padding:var(--spacing-xl) 0}.config-column{display:flex;flex-direction:column}.config-section-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.config-section-header h2{font-size:16px;font-weight:600;color:#1e4d6b;margin:0}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-size:13px;font-weight:500;color:#212529;display:block}.form-label.required:after{content:"*";color:#dc2626;margin-left:4px}.form-input{width:100%;padding:10px 12px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#212529;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.form-input::placeholder{color:#adb5bd}.form-textarea{width:100%;padding:10px 12px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#212529;font-family:inherit;resize:vertical;transition:all var(--transition-fast)}.form-textarea:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.form-textarea::placeholder{color:#adb5bd}.word-count-hint{font-size:12px;color:#6c757d;font-style:italic}.date-input-wrapper{position:relative;display:flex;align-items:center}.date-input{padding-right:40px}.date-icon{position:absolute;right:12px;color:#6c757d;pointer-events:none}.input-with-unit{display:flex;gap:var(--spacing-xs);align-items:stretch}.input-with-unit .form-input{flex:1;min-width:0}.unit-select{padding:10px 8px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#212529;cursor:pointer;min-width:60px;max-width:70px;flex-shrink:0;transition:all var(--transition-fast)}.unit-select:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.file-upload-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:4px}.file-input{display:none}.file-upload-button{display:inline-block;padding:8px 16px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;font-size:14px;font-weight:500;color:#495057;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.file-upload-button:hover{background-color:#e9ecef;border-color:#d1d5db}.file-name{font-size:14px;color:#6c757d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.config-footer{display:flex;justify-content:flex-end;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.btn-back{padding:10px 24px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;font-size:14px;font-weight:500;color:#495057;cursor:pointer;transition:all var(--transition-fast)}.btn-back:hover{background-color:#f8f9fa;border-color:#d1d5db}.btn-next{padding:10px 24px;background-color:#1e4d6b;color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-next:hover{background-color:#2a6b8f}@media(max-width:1024px){.config-form-grid{grid-template-columns:1fr;gap:var(--spacing-xl)}}@media(max-width:768px){.configuration-page{padding:var(--spacing-lg)}.config-tabs-container{flex-direction:column}.config-tab{width:100%;text-align:left;border-left:2px solid transparent;bottom:0}.config-tab.active{border-left-color:#1e4d6b}.input-with-unit{flex-direction:column}.unit-select{width:100%}}.sensor-mapping-page{width:100%;max-width:1400px;margin:0 auto;display:flex;flex-direction:column}.sensor-mapping-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:var(--spacing-xs)}.sensor-mapping-title{font-size:24px;font-weight:700;color:#212529;margin:0;text-transform:uppercase;letter-spacing:.5px}.location-indicator{font-size:14px;color:#6c757d;margin:var(--spacing-xs) 0 0 0}.sensor-mapping-actions{display:flex;gap:var(--spacing-md)}.btn-modbus{display:flex;align-items:center;gap:var(--spacing-xs);padding:10px 24px;color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-modbus:hover{background-color:#2a6b8f}.btn-save{display:flex;align-items:center;gap:var(--spacing-xs);padding:10px 24px;background-color:#10b981;color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-save:hover{background-color:#059669}.device-tabs-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;border-bottom:1px solid #e9ecef;margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:center}.view-tabs-card{margin-bottom:var(--spacing-md)}.device-management-section,.address-view-section{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-xl);background-color:#fff;box-shadow:0 1px 3px #0000000d;margin-bottom:var(--spacing-md)}.device-management-section{padding-bottom:var(--spacing-xl)}.section-title{font-size:18px;font-weight:700;color:#212529;margin:0 0 var(--spacing-lg) 0}.device-tabs-container{display:flex;gap:0;flex:1}.device-tab{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;color:#6c757d;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;bottom:-1px}.device-tab:hover{color:#212529;background-color:#f8f9fa}.device-tab.active{color:#1e4d6b;border-bottom-color:#1e4d6b;background-color:transparent}.device-tabs-actions{display:flex;gap:var(--spacing-md);align-items:center;padding-right:30px}.device-content{padding-top:0}.device-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.device-list-header h3{font-size:16px;font-weight:600;color:#212529;margin:0}.btn-add-device{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 16px;background-color:#1e4d6b;color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-add-device:hover{background-color:#2a6b8f}.add-device-form{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;margin-bottom:var(--spacing-lg)}.add-device-form .form-input{padding:10px 12px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#212529}.add-device-form .form-input:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.btn-primary{padding:10px 24px;background-color:var(--color-brand);color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 16px;background-color:#f8f9fa;color:#495057;border:1px solid #e9ecef;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background-color:#e9ecef;border-color:#d1d5db}.device-table{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.device-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px}.device-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.device-name{font-size:14px;font-weight:600;color:#212529}.device-id{font-size:12px;color:#6c757d}.device-desc{font-size:12px;color:#6c757d;font-style:italic}.device-actions{display:flex;gap:var(--spacing-xs);align-items:center}.btn-edit{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#1e4d6b;cursor:pointer;transition:all var(--transition-fast)}.btn-edit:hover{background-color:#e6f2f8;border-color:#1e4d6b}.btn-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#dc2626;cursor:pointer;transition:all var(--transition-fast)}.btn-delete:hover{background-color:#fee2e2;border-color:#dc2626}.section-header{display:flex;justify-content:space-between;align-items:center}.view-toggle{display:flex;gap:var(--spacing-xs);border:1px solid #e9ecef;border-radius:2px;overflow:hidden}.toggle-btn{padding:8px 16px;background-color:#fff;border:none;font-size:14px;font-weight:500;color:#6c757d;cursor:pointer;transition:all var(--transition-fast)}.toggle-btn:hover{background-color:#f8f9fa}.toggle-btn.active{background-color:#051925;color:#fff}.address-table-container{overflow-x:auto;border:1px solid #e9ecef;border-radius:2px}.address-table{width:100%;border-collapse:collapse;background-color:#fff}.address-table thead{background-color:#f8f9fa}.address-table th{padding:var(--spacing-md);text-align:left;font-size:13px;font-weight:600;color:#212529;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.address-table td{padding:var(--spacing-md);font-size:14px;color:#212529;border-bottom:1px solid #e9ecef}.address-table tbody tr:hover{background-color:#f8f9fa}.device-group-header{background-color:#e9ecef!important;font-weight:600}.device-group-header td{padding:var(--spacing-sm) var(--spacing-md);font-size:13px;color:#495057}.text-muted{color:#adb5bd;font-style:italic}.table-actions{display:flex;gap:var(--spacing-xs);align-items:center}.annotation-input{padding:6px 12px;background-color:#fff;border:1px solid #e9ecef;border-radius:2px;font-size:13px;color:#212529;min-width:200px}.annotation-input:focus{outline:none;border-color:#1e4d6b;box-shadow:0 0 0 3px #1e4d6b1a}.btn-icon{padding:6px 12px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;font-size:13px;color:#495057;cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background-color:#e9ecef}.btn-icon.btn-danger{color:#dc2626;border-color:#fee2e2}.btn-icon.btn-danger:hover{background-color:#fee2e2;color:#dc2626;border:1px solid #dc2626}.btn-icon.btn-map{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0}.modal-content{background-color:#fff;border-radius:4px;box-shadow:0 4px 16px #00000026;width:90%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid #e9ecef}.modal-header h3{font-size:18px;font-weight:600;color:#212529;margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:4px;color:#6c757d;cursor:pointer;transition:all var(--transition-fast);padding:0}.modal-close:hover{background-color:#f8f9fa;color:#212529}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-info{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:#f8f9fa;border-radius:4px}.modal-info p{font-size:14px;color:#212529;margin:var(--spacing-xs) 0}.modal-info p strong{color:#495057;margin-right:var(--spacing-xs)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid #e9ecef}@media(max-width:1024px){.sensor-mapping-header{flex-direction:column;gap:var(--spacing-lg)}.sensor-mapping-actions{width:100%;justify-content:flex-start}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.address-table-container{overflow-x:scroll}}@media(max-width:768px){.device-tabs-card{flex-direction:column;align-items:flex-start}.device-tabs-container{width:100%;flex-direction:column;padding:0}.device-tabs-actions{width:100%;padding:var(--spacing-md);justify-content:flex-start}.device-tab{width:100%;text-align:left;border-left:2px solid transparent;bottom:0;padding:var(--spacing-md)}.device-tab.active{border-left-color:#1e4d6b}}.pid-container{display:grid;grid-template-columns:1fr 280px;gap:var(--spacing-md);height:calc(100vh - 166px);width:100%;max-width:1400px;margin:0 auto;overflow:hidden;padding:0}.pid-container.pid-page{height:calc(100vh - 118px)}.pid-container.fullscreen{position:fixed;inset:70px 0 0;max-width:100%;height:calc(100vh - 70px);z-index:999;background-color:#f3f4f6;padding:var(--spacing-md)}.pid-left-panel,.pid-right-panel{border-radius:0;display:flex;flex-direction:column;overflow:hidden;height:100%}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #e9ecef;background-color:var(--color-surface)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#495057;cursor:pointer;transition:all var(--transition-fast);padding:0}.btn-icon:hover{background-color:#f8f9fa;color:#212529;border-color:#d1d5db}.add-diagram-form{padding:var(--spacing-md);border-bottom:1px solid #e9ecef}.add-diagram-form input{width:100%;padding:8px 12px;border:1px solid #e9ecef;border-radius:2px;font-size:14px;margin-bottom:var(--spacing-sm)}.add-diagram-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-actions{display:flex;gap:var(--spacing-xs)}.btn-small{padding:4px 12px;background-color:#0d1b26;color:#fff;border:none;border-radius:2px;font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.btn-small:hover{background-color:#0f1f2e}.diagram-list{flex:1;overflow-y:auto;padding:var(--spacing-xs)}.diagram-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);cursor:pointer;transition:background-color var(--transition-fast);border-radius:2px}.diagram-item:hover{background-color:#f8f9fa}.diagram-item.active{background-color:#0d1b261a;color:#0d1b26;font-weight:500}.diagram-name{flex:1;font-size:14px;color:#212529}.diagram-item.active .diagram-name{color:#0d1b26}.diagram-actions{display:flex;gap:var(--spacing-xs);opacity:0;transition:opacity var(--transition-fast)}.diagram-item:hover .diagram-actions{opacity:1}.btn-icon-small{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:transparent;border:none;color:#6c757d;cursor:pointer;transition:all var(--transition-fast);padding:0;border-radius:2px}.btn-icon-small:hover{background-color:#f8f9fa;color:#212529}.diagram-edit-form{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%}.diagram-edit-form input{width:100%;padding:4px 8px;border:1px solid #e9ecef;border-radius:2px;font-size:14px}.diagram-edit-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.pid-center{background-color:#fff;border-radius:0;display:flex;flex-direction:column;box-shadow:0 1px 3px #0000000d;overflow:hidden;height:100%}.pid-tabs-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.pid-tabs-container{display:flex;gap:0;flex:1}.pid-tab{padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;color:#6c757d;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;bottom:-1px}.pid-tab:hover{color:#212529;background-color:#f8f9fa}.pid-tab.active{color:#1e4d6b;border-bottom-color:#1e4d6b;background-color:transparent}.pid-tabs-actions{display:flex;gap:var(--spacing-sm);align-items:center;padding-right:var(--spacing-md)}.pid-tab-add{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#495057;cursor:pointer;transition:all var(--transition-fast);padding:0}.pid-tab-add:hover{background-color:#f8f9fa;color:#212529;border-color:#d1d5db}.pid-canvas{flex:1;position:relative;background-color:#f8f9fa;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:0}.pid-image{width:100%;height:100%;object-fit:contain;display:block;max-width:100%;max-height:100%}.placed-annotation{position:absolute;cursor:move;z-index:10}.annotation-label{background-color:#fffffff2;border:1px solid #e9ecef;border-radius:2px;padding:6px 8px;box-shadow:0 2px 4px #0000001a;min-width:120px}.annotation-label-name{font-size:11px;font-weight:600;color:#495057;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.annotation-label-value{font-size:13px;font-weight:600;color:#212529}.annotation-delete{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background-color:#dc3545;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:10px;transition:all var(--transition-fast);opacity:0}.placed-annotation:hover .annotation-delete{opacity:1}.annotation-delete:hover{background-color:#c82333}.annotations-palette{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-sm) 0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.palette-annotation-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;cursor:grab;transition:all var(--transition-fast)}.palette-annotation-item:hover{background-color:#e9ecef;border-color:#d1d5db}.palette-annotation-item:active{cursor:grabbing}.drag-handle{color:#6c757d;flex-shrink:0}.annotation-info-columns{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);align-items:center;min-width:0}.annotation-name-column{font-size:13px;font-weight:500;color:#212529;text-align:left}.annotation-value-column{display:flex;align-items:baseline;gap:4px;justify-content:flex-end;text-align:right}.annotation-value{font-size:14px;font-weight:600;color:#212529}.annotation-unit{font-size:11px;color:#6c757d}@media(max-width:1200px){.pid-container{grid-template-columns:1fr 240px}}@media(max-width:768px){.pid-container{grid-template-columns:1fr;grid-template-rows:1fr auto;height:auto}.pid-right-panel{max-height:200px}.pid-center{min-height:400px}}.reports-page{width:100%;max-width:1400px;margin:0 auto;padding:0}.reports-layout{display:grid;grid-template-columns:280px 1fr;gap:0;min-height:calc(100vh - 65px)}.reports-left-panel{background-color:#fff;border-radius:0;display:flex;flex-direction:column;box-shadow:0 1px 3px #0000000d;overflow:hidden;height:calc(100vh - 65px);gap:0;overflow-y:auto;margin-top:-25px;margin-left:-25px;position:sticky}.left-panel-section{border-bottom:1px solid #e9ecef}.left-panel-section:last-child{border-bottom:none}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #e9ecef}.panel-header h3{font-size:14px;font-weight:600;color:#212529;margin:0;text-transform:uppercase;letter-spacing:.5px}.panel-subheader{padding:var(--spacing-sm) var(--spacing-lg);background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.panel-subheader h4{font-size:12px;font-weight:600;color:#6c757d;margin:0;text-transform:uppercase;letter-spacing:.5px}.report-sections-list{padding:var(--spacing-xs);display:flex;flex-direction:column;gap:var(--spacing-xs)}.report-section-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:background-color var(--transition-fast);border-radius:2px}.report-section-item:hover{background-color:#f8f9fa}.report-section-item.active{background-color:#1e4d6b1a}.report-section-item.selected{border-left:3px solid #1e4d6b}.section-item-left{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.section-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#1e4d6b;flex-shrink:0}.section-icon{display:flex;align-items:center;justify-content:center;color:#6c757d;flex-shrink:0}.report-section-item.active .section-icon{color:#1e4d6b}.section-name{font-size:14px;color:#212529}.report-section-item.active .section-name{color:#1e4d6b;font-weight:500}.section-arrow{color:#6c757d;flex-shrink:0}.report-section-item.active .section-arrow{color:#1e4d6b}.report-types-list{padding:var(--spacing-xs)}.report-type-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);cursor:pointer;transition:background-color var(--transition-fast);border-radius:2px}.report-type-item:hover{background-color:#f8f9fa}.report-type-item.active{background-color:#0d1b261a;color:#0d1b26;font-weight:500}.report-type-icon{display:flex;align-items:center;justify-content:center;color:#6c757d;flex-shrink:0}.report-type-item.active .report-type-icon{color:#0d1b26}.report-type-name{font-size:14px;color:#212529}.report-type-item.active .report-type-name{color:#0d1b26}.modules-list{padding:var(--spacing-xs);display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:500px;overflow-y:auto}.module-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:background-color var(--transition-fast);border-radius:2px}.module-item:hover{background-color:#f8f9fa}.module-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#1e4d6b;flex-shrink:0;margin-top:2px}.module-content{flex:1;display:flex;flex-direction:column;gap:4px}.module-header{display:flex;align-items:center;gap:var(--spacing-xs)}.module-icon{display:flex;align-items:center;justify-content:center;color:#6c757d;flex-shrink:0}.module-name{font-size:14px;font-weight:500;color:#212529}.module-description{font-size:12px;color:#6c757d;font-style:italic;margin-left:24px}.reports-center{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);padding-top:0;overflow-y:auto;height:calc(100vh - 65px)}.config-tab-header{display:flex;gap:0;border-bottom:1px solid #e9ecef;background-color:#fff;box-shadow:0 1px 3px #0000000d}.config-tab{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;border-bottom:2px solid transparent;color:#6c757d;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;bottom:-1px}.config-tab:hover{color:#212529;background-color:#f8f9fa}.config-tab.active{color:#1e4d6b;border-bottom-color:#1e4d6b;background-color:transparent}.tip-box{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background-color:#e3f2fd;border-left:4px solid #1e4d6b;border-radius:2px;margin:var(--spacing-md) 0}.tip-icon{font-size:20px;flex-shrink:0}.tip-content{flex:1}.tip-content p{font-size:14px;color:#212529;margin:0;line-height:1.5}.tip-content strong{color:#1e4d6b}.btn-generate-report{display:flex;align-items:center;gap:var(--spacing-xs);padding:12px 24px;background-color:#1e4d6b;color:#fff;border:none;border-radius:2px;font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin:0 auto}.btn-generate-report:hover:not(:disabled){background-color:#2a6b8f}.btn-generate-report:disabled{opacity:.5;cursor:not-allowed}.section-config-view{background-color:#fff;border-radius:0;box-shadow:0 1px 3px #0000000d;overflow:hidden}.section-config-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #e9ecef}.section-config-header h3{font-size:16px;font-weight:600;color:#212529;margin:0}.btn-close-section{padding:6px 12px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#495057;cursor:pointer;transition:all var(--transition-fast)}.btn-close-section:hover{background-color:#e9ecef;border-color:#d1d5db}.section-config-content{padding:var(--spacing-lg)}.report-type-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.report-type-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 16px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#495057;cursor:pointer;transition:all var(--transition-fast)}.report-type-button:hover{background-color:#e9ecef;border-color:#d1d5db}.report-type-button.active{background-color:#1e4d6b;color:#fff;border-color:#1e4d6b}.parameters-section,.actions-section,.preview-section{background-color:#fff;border-radius:0;box-shadow:0 1px 3px #0000000d}.section-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #e9ecef}.section-header h3{font-size:16px;font-weight:600;color:#212529;margin:0}.config-description{padding:0 var(--spacing-lg) var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #e9ecef}.config-description p{font-size:14px;color:#6c757d;margin:0;line-height:1.5}.parameters-content{padding:var(--spacing-lg)}.parameter-group{margin-bottom:var(--spacing-lg)}.parameter-group:last-child{margin-bottom:0}.parameter-label{display:block;font-size:14px;font-weight:500;color:#212529;margin-bottom:var(--spacing-sm)}.time-range-controls{display:flex;flex-direction:column;gap:var(--spacing-md)}.preset-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.preset-btn{padding:6px 12px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:2px;font-size:13px;color:#495057;cursor:pointer;transition:all var(--transition-fast)}.preset-btn:hover{background-color:#e9ecef;border-color:#d1d5db}.preset-btn.active{background-color:#0d1b26;color:#fff;border-color:#0d1b26}.date-inputs{display:flex;align-items:center;gap:var(--spacing-sm)}.date-input{padding:8px 12px;border:1px solid #e9ecef;border-radius:2px;font-size:14px;color:#495057;background-color:#fff;flex:1}.date-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.date-separator{font-size:14px;color:#6c757d;flex-shrink:0}.annotations-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-sm);background-color:#f8f9fa;border:1px solid #e9ecef;padding:var(--spacing-md);max-height:300px;overflow-y:auto}.checkbox-item{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:13px;color:#495057}.checkbox-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;flex-shrink:0}.checkbox-label{-webkit-user-select:none;user-select:none}.grouping-options{display:flex;gap:var(--spacing-lg)}.radio-item{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:14px;color:#495057}.radio-item input[type=radio]{cursor:pointer;width:16px;height:16px}.actions-section{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl)}.btn-action{display:flex;align-items:center;gap:var(--spacing-xs);padding:10px 16px;border-radius:2px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-action.btn-primary{background-color:var(--color-brand);color:#fff}.btn-action.btn-primary:hover:not(:disabled){background-color:#0f1f2e}.btn-action.btn-secondary{background-color:#0d1b26;color:#fff;border:1px solid rgba(255,255,255,.1)}.btn-action.btn-secondary:hover:not(:disabled){background-color:#0f1f2e}.btn-action.btn-tertiary{background-color:#f8f9fa;color:#495057;border:1px solid #e9ecef}.btn-action.btn-tertiary:hover:not(:disabled){background-color:#e9ecef;border-color:#d1d5db}.preview-content{padding:var(--spacing-lg)}.preview-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid #e9ecef}.info-label{font-size:12px;font-weight:500;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:14px;font-weight:600;color:#212529}.preview-table{overflow-x:auto}.preview-table table{width:100%;border-collapse:collapse}.preview-table thead{background-color:#f8f9fa}.preview-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:13px;font-weight:600;color:#212529;border-bottom:2px solid #e9ecef;white-space:nowrap}.preview-table td{padding:var(--spacing-sm) var(--spacing-md);font-size:13px;color:#495057;border-bottom:1px solid #f8f9fa}.preview-table tbody tr:hover{background-color:#f8f9fa}@media(max-width:1200px){.reports-layout{grid-template-columns:260px 1fr}}@media(max-width:768px){.reports-page{padding:0}.reports-layout{grid-template-columns:1fr;min-height:auto}.reports-left-panel{order:2;height:auto;max-height:400px}.reports-center{order:1;padding:var(--spacing-lg);height:auto}}.alerts-page{width:100%;max-width:1400px;margin:0 auto;display:flex;flex-direction:column}.alerts-toolbar{margin-bottom:var(--spacing-md)}.btn-primary{display:flex;align-items:center;gap:var(--spacing-xs);padding:10px 24px;background-color:var(--color-brand);color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-primary:hover{background-color:#2a6b8f}.alerts-content-card{background-color:#fff;box-shadow:0 1px 3px #0000000d;padding:var(--spacing-xl)}.alerts-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xxl);text-align:center;color:#6c757d}.alerts-empty p{font-size:14px;margin-bottom:var(--spacing-lg)}.alerts-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.alert-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-lg);background-color:#fff;border:1px solid #e9ecef;border-radius:2px;transition:all var(--transition-fast)}.alert-item:hover{box-shadow:0 2px 4px #0000000d;border-color:#d1d5db}.alert-item.inactive{opacity:.6}.alert-main-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.alert-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-xs)}.alert-name{font-size:16px;font-weight:600;color:#212529;margin:0}.alert-meta{display:flex;gap:var(--spacing-sm);align-items:center;flex-shrink:0}.alert-status-badge{padding:4px 12px;border-radius:2px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.alert-status-badge.active{background-color:#dcfce7;color:#166534}.alert-status-badge.inactive{background-color:#f3f4f6;color:#6c757d}.alert-severity-badge{padding:4px 12px;border-radius:2px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.alert-severity-badge.high{background-color:#fee2e2;color:#991b1b}.alert-severity-badge.medium{background-color:#fef3c7;color:#92400e}.alert-severity-badge.low{background-color:#dbeafe;color:#1e40af}.alert-condition{font-size:14px;color:#495057;margin:0;padding-left:var(--spacing-md)}.alert-actions{margin-top:var(--spacing-xs);padding-left:var(--spacing-md)}.btn-acknowledge{padding:6px 16px;background-color:#1e4d6b;color:#fff;border:none;border-radius:2px;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-acknowledge:hover{background-color:#2a6b8f}.alert-acknowledged{margin-top:var(--spacing-xs);padding-left:var(--spacing-md);font-size:13px;color:#10b981;font-weight:500}.alert-item-actions{display:flex;gap:var(--spacing-xs);align-items:center;flex-shrink:0;margin-left:var(--spacing-md)}.alert-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#495057;cursor:pointer;transition:all var(--transition-fast);padding:0}.alert-action-btn:hover{background-color:#f8f9fa;border-color:#d1d5db;color:#212529}.alert-action-btn.alert-action-delete:hover{background-color:#fee2e2;border-color:#dc2626;color:#dc2626}@media(max-width:768px){.alert-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.alert-meta{width:100%}.alert-item{flex-direction:column;gap:var(--spacing-md)}.alert-item-actions{margin-left:0;align-self:flex-end}}.users-page{width:100%;max-width:1400px;margin:0 auto;padding:var(--spacing-lg)}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.users-header h2{font-size:24px;font-weight:600;color:#212529;margin:0}.btn-primary{display:flex;align-items:center;gap:var(--spacing-xs);padding:10px 16px;background-color:var(--color-brand);color:#fff;border:none;border-radius:2px;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.staff-form .btn-primary{padding:8px 16px;font-size:13px}.staff-table-container{background-color:#fff;border-radius:0;box-shadow:0 1px 3px #0000000d;overflow:hidden}.staff-table{width:100%;border-collapse:collapse}.staff-table thead{background-color:#f8f9fa}.staff-table th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-size:13px;font-weight:600;color:#212529;border-bottom:2px solid #e9ecef;text-transform:uppercase;letter-spacing:.5px}.staff-table td{padding:var(--spacing-md) var(--spacing-lg);font-size:14px;color:#495057;border-bottom:1px solid #f8f9fa}.staff-table tbody tr:hover{background-color:#f8f9fa}.role-badge{display:inline-block;padding:4px 12px;border-radius:2px;font-size:12px;font-weight:500;text-transform:capitalize}.role-staff{background-color:#2563eb1a;color:#2563eb}.role-viewer{background-color:#10b9811a;color:#10b981}.role-custom{background-color:#8b45131a;color:#8b4513}.status-badge{display:inline-block;padding:4px 12px;border-radius:2px;font-size:12px;font-weight:500;text-transform:capitalize}.status-active{background-color:#10b9811a;color:#10b981}.status-inactive{background-color:#6b72801a;color:#6b7280}.action-buttons{display:flex;gap:var(--spacing-xs)}.btn-icon-small{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:transparent;border:1px solid #e9ecef;border-radius:2px;color:#6c757d;cursor:pointer;transition:all var(--transition-fast);padding:0}.btn-icon-small:hover{background-color:#f8f9fa;color:#212529;border-color:#d1d5db}.btn-icon-small.btn-danger:hover{background-color:#dc35451a;color:#dc3545;border-color:#dc3545}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1050;padding:var(--spacing-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--color-surface, #ffffff);border-radius:var(--radius-lg, 12px);width:100%;max-width:800px;max-height:calc(100vh - 48px);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 48px #0003,0 0 0 1px #0000000d;margin:auto;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-xl, 24px) var(--spacing-xl, 24px) var(--spacing-lg, 20px);border-bottom:1px solid var(--color-border, #e9ecef);flex-shrink:0;background:linear-gradient(to bottom,var(--color-surface, #ffffff),var(--color-surface-elevated, #f8f9fa))}.modal-header-content{flex:1}.modal-header h3{font-size:22px;font-weight:600;color:var(--color-text-primary, #212529);margin:0 0 var(--spacing-xs, 4px) 0;letter-spacing:-.02em}.modal-subtitle{font-size:14px;color:var(--color-text-secondary, #6c757d);margin:0;line-height:1.5}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:transparent;border:none;color:var(--color-text-secondary, #6c757d);cursor:pointer;transition:all var(--transition-fast, .15s ease);border-radius:var(--radius-md, 8px);padding:0;margin-left:var(--spacing-md, 16px);flex-shrink:0}.modal-close:hover{background-color:var(--color-surface-hover, #f8f9fa);color:var(--color-text-primary, #212529);transform:rotate(90deg)}.staff-form{padding:0;overflow-y:auto;flex:1;display:flex;flex-direction:column}.form-body{padding:var(--spacing-xl, 24px);display:flex;flex-direction:column;gap:var(--spacing-lg, 24px);flex:1;overflow-y:auto}.form-section-card{background-color:var(--color-surface-elevated, #f8f9fa);border:1px solid var(--color-border, #e9ecef);border-radius:var(--radius-lg, 12px);padding:var(--spacing-lg, 20px);transition:all var(--transition-normal, .2s ease)}.form-section-card:hover{border-color:var(--color-border-light, #dee2e6);box-shadow:0 2px 8px #0000000a}.form-section-header{margin-bottom:var(--spacing-md, 16px);padding-bottom:var(--spacing-md, 16px);border-bottom:1px solid var(--color-border, #e9ecef)}.form-section-title{font-size:16px;font-weight:600;color:var(--color-text-primary, #212529);margin:0 0 var(--spacing-xs, 4px) 0;letter-spacing:-.01em}.form-section-description{font-size:13px;color:var(--color-text-secondary, #6c757d);margin:0;line-height:1.5}.form-fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md, 16px)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs, 6px)}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--color-text-primary, #212529);margin-bottom:var(--spacing-xs, 6px);letter-spacing:.01em}.form-group .required{margin-left:2px}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password]{width:100%;padding:12px 14px;border:1.5px solid var(--color-border, #dee2e6);border-radius:var(--radius-md, 8px);font-size:14px;color:var(--color-text-primary, #212529);background-color:var(--color-surface, #ffffff);box-sizing:border-box;transition:all var(--transition-fast, .15s ease);font-family:inherit}.form-group input[type=text]:hover,.form-group input[type=email]:hover,.form-group input[type=password]:hover{border-color:var(--color-border-light, #d1d5db)}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=password]:focus{outline:none;border-color:var(--color-primary, #6366f1);box-shadow:0 0 0 3px #6366f11a}.form-group input[type=text]::placeholder,.form-group input[type=email]::placeholder,.form-group input[type=password]::placeholder{color:var(--color-text-tertiary, #adb5bd)}.password-section{margin-top:var(--spacing-md, 16px);padding-top:var(--spacing-md, 16px);border-top:1px solid var(--color-border, #e9ecef)}.checkbox-label-default{display:flex;align-items:center;gap:var(--spacing-sm, 8px);cursor:pointer;font-size:14px;font-weight:500;color:var(--color-text-primary, #212529);margin-bottom:var(--spacing-xs, 4px)}.checkbox-label-default input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary, #6366f1)}.checkbox-help-text{font-size:12px;color:var(--color-text-secondary, #6c757d);margin:0 0 var(--spacing-md, 16px) 26px;line-height:1.4}.password-input-wrapper{margin-top:var(--spacing-md, 16px);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.form-group label input[type=checkbox]{margin-right:8px;cursor:pointer;width:16px;height:16px;vertical-align:middle}.form-group label span{font-size:13px;color:#495057;vertical-align:middle}.multi-select-container{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs, 8px);background-color:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e9ecef);padding:var(--spacing-md, 16px);border-radius:var(--radius-md, 8px);max-height:200px;overflow-y:auto}.multi-select-container::-webkit-scrollbar{width:6px}.multi-select-container::-webkit-scrollbar-track{background:var(--color-surface-elevated, #f8f9fa);border-radius:3px}.multi-select-container::-webkit-scrollbar-thumb{background:var(--color-border-light, #ced4da);border-radius:3px}.multi-select-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary, #adb5bd)}.checkbox-item-modern{display:flex;align-items:center;gap:var(--spacing-sm, 12px);cursor:pointer;font-size:14px;color:var(--color-text-primary, #212529);padding:var(--spacing-sm, 10px) var(--spacing-md, 12px);border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease);-webkit-user-select:none;user-select:none;position:relative}.checkbox-item-modern:hover{background-color:var(--color-surface-hover, #f1f3f5)}.checkbox-item-modern input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{position:relative;width:20px;height:20px;border:2px solid var(--color-border, #dee2e6);border-radius:var(--radius-sm, 4px);background-color:var(--color-surface, #ffffff);transition:all var(--transition-fast, .15s ease);flex-shrink:0}.checkbox-item-modern input[type=checkbox]:checked+.checkbox-custom{background-color:var(--color-primary, #6366f1);border-color:var(--color-primary, #6366f1)}.checkbox-item-modern input[type=checkbox]:checked+.checkbox-custom:after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-item-modern input[type=checkbox]:focus+.checkbox-custom{box-shadow:0 0 0 3px #6366f11a}.checkbox-label{flex:1;font-weight:500}.module-permissions{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm, 12px);background-color:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e9ecef);padding:var(--spacing-md, 16px);border-radius:var(--radius-md, 8px);max-height:400px;overflow-y:auto}.module-permissions::-webkit-scrollbar{width:6px}.module-permissions::-webkit-scrollbar-track{background:var(--color-surface-elevated, #f8f9fa);border-radius:3px}.module-permissions::-webkit-scrollbar-thumb{background:var(--color-border-light, #dee2e6);border-radius:3px}.module-permissions::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary, #ced4da)}.module-permission-item-modern{display:flex;flex-direction:column;gap:var(--spacing-sm, 12px);padding:var(--spacing-md, 16px);background-color:var(--color-surface-elevated, #f8f9fa);border:1.5px solid var(--color-border, #e9ecef);border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.module-permission-item-modern:hover{background-color:var(--color-surface-hover, #f1f3f5);border-color:var(--color-border-light, #dee2e6);box-shadow:0 2px 4px #0000000a}.module-permission-item-modern.active{background-color:var(--color-surface, #ffffff);border-color:var(--color-primary, #6366f1);box-shadow:0 0 0 3px #6366f114}.module-checkbox-modern{display:flex;align-items:center;gap:var(--spacing-sm, 12px);cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text-primary, #212529);-webkit-user-select:none;user-select:none}.module-checkbox-modern input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.module-checkbox-modern .checkbox-custom{position:relative;width:20px;height:20px;border:2px solid var(--color-border, #dee2e6);border-radius:var(--radius-sm, 4px);background-color:var(--color-surface, #ffffff);transition:all var(--transition-fast, .15s ease);flex-shrink:0}.module-checkbox-modern input[type=checkbox]:checked+.checkbox-custom{background-color:var(--color-primary, #6366f1);border-color:var(--color-primary, #6366f1)}.module-checkbox-modern input[type=checkbox]:checked+.checkbox-custom:after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.module-checkbox-modern input[type=checkbox]:focus+.checkbox-custom{box-shadow:0 0 0 3px #6366f11a}.module-name{flex:1}.permission-types-modern{display:flex;gap:var(--spacing-xs, 8px);margin-left:32px;padding-top:var(--spacing-xs, 8px);flex-wrap:wrap;animation:fadeIn .2s ease-out}.radio-item-modern{display:flex;align-items:center;gap:var(--spacing-xs, 8px);cursor:pointer;font-size:13px;color:var(--color-text-secondary, #495057);-webkit-user-select:none;user-select:none;padding:var(--spacing-xs, 6px) var(--spacing-sm, 10px);border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease);border:1.5px solid transparent;background-color:var(--color-surface-elevated, #f8f9fa)}.radio-item-modern:hover{background-color:var(--color-surface-hover, #f1f3f5);border-color:var(--color-border-light, #dee2e6)}.radio-item-modern.selected{background-color:#6366f11a;border-color:var(--color-primary, #6366f1);color:var(--color-primary, #6366f1);font-weight:500}.radio-item-modern input[type=radio]{position:absolute;opacity:0;width:0;height:0}.radio-custom{position:relative;width:18px;height:18px;border:2px solid var(--color-border, #dee2e6);border-radius:50%;background-color:var(--color-surface, #ffffff);transition:all var(--transition-fast, .15s ease);flex-shrink:0}.radio-item-modern input[type=radio]:checked+.radio-custom{border-color:var(--color-primary, #6366f1)}.radio-item-modern input[type=radio]:checked+.radio-custom:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background-color:var(--color-primary, #6366f1)}.radio-item-modern input[type=radio]:focus+.radio-custom{box-shadow:0 0 0 3px #6366f11a}.radio-label{flex:1}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm, 12px);padding:var(--spacing-lg, 20px) var(--spacing-xl, 24px);border-top:1px solid var(--color-border, #e9ecef);flex-shrink:0;position:sticky;bottom:0;background-color:var(--color-surface, #ffffff);z-index:10;box-shadow:0 -4px 12px #00000005}.btn-secondary{padding:11px 24px;background-color:var(--color-surface, #ffffff);color:var(--color-text-primary, #212529);border:1.5px solid var(--color-border, #dee2e6);border-radius:var(--radius-md, 8px);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s ease);font-family:inherit}.btn-secondary:hover{background-color:var(--color-surface-hover, #f8f9fa);border-color:var(--color-border-light, #d1d5db);color:var(--color-text-primary, #212529);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.btn-secondary:active{transform:translateY(0)}.staff-form .btn-primary{padding:11px 24px;font-size:14px;border-radius:var(--radius-md, 8px);font-weight:600;box-shadow:0 2px 4px #6366f133;transition:all var(--transition-fast, .15s ease)}.staff-form .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 8px #6366f14d}.staff-form .btn-primary:active{transform:translateY(0)}@media(max-width:768px){.users-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.staff-table{font-size:12px}.staff-table th,.staff-table td{padding:var(--spacing-sm)}.modal-overlay{padding:var(--spacing-sm, 8px)}.modal-content{max-height:calc(100vh - 16px);border-radius:var(--radius-md, 8px)}.modal-header{padding:var(--spacing-lg, 20px) var(--spacing-md, 16px);flex-direction:column;align-items:flex-start;gap:var(--spacing-sm, 12px)}.modal-close{position:absolute;top:var(--spacing-md, 16px);right:var(--spacing-md, 16px);margin-left:0}.form-body{padding:var(--spacing-md, 16px);gap:var(--spacing-md, 16px)}.form-fields-grid{grid-template-columns:1fr}.form-section-card{padding:var(--spacing-md, 16px)}.multi-select-container,.module-permissions{grid-template-columns:1fr}.permission-types-modern{flex-direction:column;gap:var(--spacing-xs, 6px)}.form-actions{padding:var(--spacing-md, 16px);flex-direction:column-reverse}.form-actions button{width:100%}}.profile-container{max-width:800px;margin:0 auto}.profile-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e9ecef}.profile-tab{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:#6c757d;transition:all .2s;margin-bottom:-2px}.profile-tab:hover{color:#212529}.profile-tab.active{color:#2563eb;border-bottom-color:#2563eb}.profile-section{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px}.profile-section h3{font-size:18px;font-weight:600;margin:0 0 8px;color:#212529}.profile-section-description{font-size:14px;color:#6c757d;margin:0 0 24px}.profile-section .form-group{margin-bottom:20px}.profile-section .form-group label{display:block;font-size:14px;font-weight:500;color:#212529;margin-bottom:8px}.profile-section .form-group input,.profile-section .form-group select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s}.profile-section .form-group input:focus,.profile-section .form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn-primary{padding:10px 24px;background-color:#2563eb;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:#1d4ed8}.profile-message{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px}.profile-message.success{background-color:#22c55e1a;color:#16a34a;border:1px solid rgba(34,197,94,.2)}.profile-message.error{background-color:#dc26261a;color:#dc2626;border:1px solid rgba(220,38,38,.2)}.notification-preferences{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.notification-preference-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .2s}.notification-preference-item:hover{border-color:#2563eb;background-color:#2563eb05}.notification-preference-item input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer}.notification-preference-content{flex:1;display:flex;flex-direction:column;gap:4px}.notification-preference-label{font-size:14px;font-weight:500;color:#212529}.notification-preference-description{font-size:13px;color:#6c757d}.super-admin-dashboard{width:100%}.dashboard-actions{display:flex;gap:12px;margin-bottom:24px}.btn-primary{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:var(--color-brand);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:var(--color-brand-hover)}.btn-secondary{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:#fff;color:#2563eb;border:1px solid #2563eb;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background-color:#2563eb0d}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px}.kpi-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px;transition:box-shadow .2s}.kpi-card:hover{box-shadow:0 4px 12px #0000001a}.kpi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kpi-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center}.kpi-title{font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px}.kpi-value{font-size:32px;font-weight:700;color:#212529;margin:0 0 8px}.kpi-trend{font-size:14px;color:#6c757d}.dashboard-sections{display:grid;grid-template-columns:1fr 1fr;gap:24px}.dashboard-section{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-title{font-size:18px;font-weight:600;color:#212529;margin:0}.btn-link{background:none;border:none;color:#2563eb;font-size:14px;font-weight:500;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.clients-list{display:flex;flex-direction:column;gap:12px}.client-card{display:flex;align-items:center;gap:16px;padding:16px;border:1px solid #e9ecef;border-radius:6px;transition:all .2s}.client-card:hover{border-color:#2563eb;background-color:#2563eb05}.client-rank{font-size:18px;font-weight:700;color:#6c757d;min-width:32px}.client-info{flex:1}.client-name{font-size:16px;font-weight:600;color:#212529;margin-bottom:4px}.client-stats{font-size:14px;color:#6c757d;display:flex;gap:8px}.client-arrow{font-size:20px;color:#6c757d}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.quick-action-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#212529}.quick-action-card:hover{background:#fff;border-color:#2563eb;box-shadow:0 4px 12px #0000001a}.quick-action-card svg{color:#2563eb}@media(max-width:1024px){.dashboard-sections{grid-template-columns:1fr}}.clients-management{width:100%}.page-header-actions{margin-bottom:24px}.clients-table-container{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden}.clients-table{width:100%;border-collapse:collapse}.clients-table thead{background-color:#f8f9fa}.clients-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.clients-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px}.clients-table tbody tr:hover{background-color:#f8f9fa}.client-name-cell{display:flex;flex-direction:column;gap:4px}.client-name{font-weight:600;color:#212529}.client-contact{font-size:12px;color:#6c757d}.plan-badge{display:inline-block;padding:4px 12px;background-color:#2563eb1a;color:#2563eb;border-radius:12px;font-size:12px;font-weight:500}.locations-progress{display:flex;align-items:center;gap:12px;min-width:120px}.progress-bar{flex:1;height:6px;background-color:#e9ecef;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background-color:#2563eb;transition:width .3s}.client-form{padding:24px}.plans-management{width:100%}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.plan-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px;transition:box-shadow .2s}.plan-card:hover{box-shadow:0 4px 12px #0000001a}.plan-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #e9ecef}.plan-name{font-size:20px;font-weight:600;color:#212529;margin:0 0 8px}.plan-description{font-size:14px;color:#6c757d;margin:0}.plan-details{display:flex;flex-direction:column;gap:16px}.plan-detail-item{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:14px;color:#6c757d}.detail-value{font-size:16px;font-weight:600;color:#212529}.plan-features{display:flex;flex-direction:column;gap:12px;margin-top:8px}.feature-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.feature-label{font-size:14px;color:#212529}.feature-value{font-size:14px;font-weight:600;color:#212529}.feature-enabled{color:#16a34a}.feature-disabled{color:#dc2626}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.plan-form{padding:24px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-section{margin:24px 0;padding:20px;background-color:#f8f9fa;border-radius:6px}.form-section-title{font-size:16px;font-weight:600;color:#212529;margin:0 0 16px}.feature-flags{display:flex;flex-direction:column;gap:12px}.feature-flag-item{display:flex;align-items:center;gap:12px;cursor:pointer}.feature-flag-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.feature-flag-item span{font-size:14px;color:#212529}.admin-accounts-management{width:100%}.admins-table-container{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden}.admins-table{width:100%;border-collapse:collapse}.admins-table thead{background-color:#f8f9fa}.admins-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.admins-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px}.admins-table tbody tr:hover{background-color:#f8f9fa}.admin-name{font-weight:600;color:#212529}.client-badge{display:inline-block;padding:4px 12px;background-color:#2563eb1a;color:#2563eb;border-radius:12px;font-size:12px;font-weight:500}.status-toggle{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background-color .2s;font-size:14px;font-weight:500}.status-toggle:hover{background-color:#2563eb0d}.status-toggle.active{color:#16a34a}.status-toggle.locked{color:#dc2626}.action-buttons{display:flex;gap:8px}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;color:#6c757d;transition:all .2s}.btn-icon:hover{border-color:#2563eb;color:#2563eb;background-color:#2563eb0d}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e9ecef}.modal-header h2{font-size:20px;font-weight:600;margin:0;color:#212529}.modal-close{background:none;border:none;cursor:pointer;color:#6c757d;padding:4px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#212529}.admin-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#212529;margin-bottom:8px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group small{display:block;margin-top:4px;font-size:12px;color:#6c757d}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px;border-top:1px solid #e9ecef}.btn-secondary{padding:10px 20px;background-color:#fff;color:#212529;border:1px solid #e9ecef;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{border-color:#ced4da;background-color:#f8f9fa}.client-view{width:100%}.back-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;color:#6c757d;transition:all .2s}.back-button:hover{border-color:#2563eb;color:#2563eb;background-color:#2563eb0d}.client-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px}.client-info-card{flex:1;background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px}.client-info-card h3{font-size:18px;font-weight:600;color:#212529;margin:0 0 20px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:12px;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:14px;font-weight:500;color:#212529}.view-as-client-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:#2563eb;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.view-as-client-btn:hover{background-color:#1d4ed8}.client-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e9ecef}.client-tab{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:#6c757d;transition:all .2s;margin-bottom:-2px}.client-tab:hover{color:#212529}.client-tab.active{color:#2563eb;border-bottom-color:#2563eb}.client-tab-content{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:24px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.stat-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center}.stat-content{flex:1}.stat-value{font-size:24px;font-weight:700;color:#212529;margin-bottom:4px}.stat-label{font-size:12px;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.locations-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.location-card{padding:16px;border:1px solid #e9ecef;border-radius:6px;background:#fff}.location-info{display:flex;justify-content:space-between;align-items:center}.location-name{font-size:16px;font-weight:600;color:#212529}.location-stats{display:flex;align-items:center;gap:12px;font-size:14px;color:#6c757d}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.status-active{background-color:#22c55e1a;color:#16a34a}.status-badge.status-inactive{background-color:#6b72801a;color:#6b7280}.read-only-notice{padding:16px;background-color:#2563eb0d;border:1px solid rgba(37,99,235,.2);border-radius:6px;color:#2563eb;font-size:14px;text-align:center}.data-usage-section h3{font-size:18px;font-weight:600;color:#212529;margin:0 0 20px}.data-stats{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.data-stat-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e9ecef}.data-stat-label{font-size:14px;color:#6c757d}.data-stat-value{font-size:16px;font-weight:600;color:#212529}.loggers-list h4{font-size:16px;font-weight:600;color:#212529;margin:0 0 16px}.loggers-table{width:100%;border-collapse:collapse}.loggers-table thead{background-color:#f8f9fa}.loggers-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.loggers-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;font-size:14px}.loggers-table tbody tr:hover{background-color:#f8f9fa}.audit-logs{width:100%}.logs-header{display:flex;gap:12px;margin-bottom:20px}.search-bar{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#6c757d;pointer-events:none}.search-input{width:100%;padding:10px 12px 10px 40px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.filter-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:#fff;color:#212529;border:1px solid #e9ecef;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.filter-button:hover{border-color:#ced4da;background-color:#f8f9fa}.filters-panel{display:flex;gap:16px;padding:16px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:20px}.filter-group{display:flex;flex-direction:column;gap:8px;min-width:200px}.filter-group label{font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.filter-group select{padding:8px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;background-color:#fff;cursor:pointer}.filter-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.logs-table-container{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden}.logs-table{width:100%;border-collapse:collapse}.logs-table thead{background-color:#f8f9fa}.logs-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.logs-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px}.logs-table tbody tr:hover{background-color:#f8f9fa}.timestamp-cell{font-family:Courier New,monospace;font-size:13px;color:#6c757d;white-space:nowrap}.user-cell{display:flex;flex-direction:column;gap:4px}.user-name{font-weight:600;color:#212529}.user-email{font-size:12px;color:#6c757d}.action-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.action-badge.action-login{background-color:#22c55e1a;color:#16a34a}.action-badge.action-mapping-change{background-color:#2563eb1a;color:#2563eb}.action-badge.action-threshold-change{background-color:#ea580c1a;color:#ea580c}.action-badge.action-report-download{background-color:#8b5cf61a;color:#8b5cf6}.details-cell{max-width:300px;color:#6c757d}.ip-cell{font-family:Courier New,monospace;font-size:13px;color:#6c757d}.no-results{padding:48px;text-align:center;color:#6c757d}.no-results p{margin:0;font-size:14px}
