:root{--color-bg-primary: #0a0f14;--color-bg-secondary: #111820;--color-bg-tertiary: #1a232e;--color-bg-card: #151d27;--color-bg-card-hover: #1c2735;--color-border: #2a3744;--color-border-light: #3a4754;--color-text-primary: #f0f4f8;--color-text-secondary: #8a9bae;--color-text-muted: #5a6b7e;--color-teal: #0d9488;--color-teal-light: #14b8a6;--color-teal-dark: #0a7569;--color-teal-glow: rgba(13, 148, 136, .3);--color-green: #22c55e;--color-green-bg: rgba(34, 197, 94, .12);--color-green-border: rgba(34, 197, 94, .3);--color-amber: #f59e0b;--color-amber-bg: rgba(245, 158, 11, .12);--color-amber-border: rgba(245, 158, 11, .3);--color-red: #ef4444;--color-red-bg: rgba(239, 68, 68, .12);--color-red-border: rgba(239, 68, 68, .3);--color-chart-baseline: #64748b;--color-chart-actual: var(--color-teal-light);--color-chart-guaranteed: var(--color-amber);--color-chart-prediction: #818cf8;--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Consolas", monospace;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--color-teal-glow);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-weight:400;line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary);min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 0%,rgba(13,148,136,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(13,148,136,.05) 0%,transparent 50%);pointer-events:none;z-index:-1}#root{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-text-primary)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}.text-mono{font-family:var(--font-mono)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.layout{display:flex;flex-direction:column;min-height:100vh}.header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.logo-icon{width:32px;height:32px;background:var(--color-teal);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.logo-icon svg{width:20px;height:20px;color:#fff}.logo-text span{color:var(--color-teal-light)}.nav{display:flex;align-items:center;gap:var(--spacing-sm)}.nav-link{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast)}.nav-link:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.nav-link.active{color:var(--color-teal-light);background:var(--color-teal-glow)}.main{flex:1;padding:var(--spacing-xl)}.main-inner{max-width:1400px;margin:0 auto}.page-header{margin-bottom:var(--spacing-xl)}.page-title{font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-xs)}.page-subtitle{color:var(--color-text-secondary);font-size:.9375rem}.breadcrumb{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-size:.875rem;color:var(--color-text-muted)}.breadcrumb a{color:var(--color-text-secondary);transition:color var(--transition-fast)}.breadcrumb a:hover{color:var(--color-teal-light)}.breadcrumb-separator{color:var(--color-text-muted)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-normal)}.card:hover{border-color:var(--color-border-light)}.card-clickable{cursor:pointer}.card-clickable:hover{background:var(--color-bg-card-hover);box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.card-title{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.card-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.kpi-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-teal)}.kpi-card.green:before{background:var(--color-green)}.kpi-card.amber:before{background:var(--color-amber)}.kpi-card.red:before{background:var(--color-red)}.kpi-label{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.kpi-value{font-family:var(--font-mono);font-size:1.75rem;font-weight:600;color:var(--color-text-primary);line-height:1.2}.kpi-value.green{color:var(--color-green)}.kpi-value.amber{color:var(--color-amber)}.kpi-value.red{color:var(--color-red)}.kpi-detail{font-size:.8125rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.semaphore{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.semaphore.green{background:var(--color-green-bg);color:var(--color-green);border:1px solid var(--color-green-border)}.semaphore.amber{background:var(--color-amber-bg);color:var(--color-amber);border:1px solid var(--color-amber-border)}.semaphore.red{background:var(--color-red-bg);color:var(--color-red);border:1px solid var(--color-red-border)}.semaphore-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.live-indicator{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:20px;font-size:.75rem;font-weight:600;color:var(--color-green);text-transform:uppercase;letter-spacing:.08em;margin-left:var(--spacing-md);vertical-align:middle}.live-indicator-dot{position:relative;width:8px;height:8px}.live-indicator-dot:before,.live-indicator-dot:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--color-green)}.live-indicator-dot:before{animation:live-ping 1.5s cubic-bezier(0,0,.2,1) infinite}.live-indicator-dot:after{animation:live-pulse 1.5s ease-in-out infinite}@keyframes live-ping{0%{transform:scale(1);opacity:1}75%,to{transform:scale(2.5);opacity:0}}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.9)}}.page-title-wrapper{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-xs)}.projects-table-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.projects-table{width:100%;border-collapse:collapse}.projects-table th,.projects-table td{padding:var(--spacing-md) var(--spacing-lg);text-align:left}.projects-table th{background:var(--color-bg-tertiary);font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.projects-table td{border-bottom:1px solid var(--color-border);font-size:.9375rem}.projects-table tbody tr{cursor:pointer;transition:background var(--transition-fast)}.projects-table tbody tr:hover{background:var(--color-bg-card-hover)}.projects-table tbody tr:last-child td{border-bottom:none}.project-name{font-weight:500;color:var(--color-text-primary)}.project-id{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.project-type{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:.8125rem;color:var(--color-text-secondary)}.project-type-icon{font-size:1rem}.value-cell{font-family:var(--font-mono);font-weight:500}.value-cell.positive{color:var(--color-green)}.fve-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fbbf241a;border:1px solid rgba(251,191,36,.2);border-radius:var(--radius-sm);font-size:.75rem;color:#fbbf24}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.chart-title{font-size:1rem;font-weight:600;color:var(--color-text-primary)}.chart-legend{display:flex;gap:var(--spacing-md)}.legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--color-text-secondary)}.legend-dot{width:10px;height:10px;border-radius:2px}.legend-dot.baseline{background:var(--color-chart-baseline)}.legend-dot.actual{background:var(--color-chart-actual)}.legend-dot.guaranteed{background:var(--color-chart-guaranteed)}.legend-dot.prediction{background:var(--color-chart-prediction)}.chart-container{height:280px}.warning-card{background:var(--color-red-bg);border:1px solid var(--color-red-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.warning-card.amber{background:var(--color-amber-bg);border-color:var(--color-amber-border)}.warning-header{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.warning-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--color-red);color:#fff;font-size:1.25rem;flex-shrink:0}.warning-card.amber .warning-icon{background:var(--color-amber)}.warning-title{font-size:1.125rem;font-weight:600;color:var(--color-red);margin-bottom:var(--spacing-xs)}.warning-card.amber .warning-title{color:var(--color-amber)}.warning-subtitle{font-size:.875rem;color:var(--color-text-secondary)}.warning-content{display:grid;gap:var(--spacing-md);padding-left:calc(40px + var(--spacing-md))}.warning-section h4{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.warning-section p{font-size:.9375rem;color:var(--color-text-primary);line-height:1.5}.scenario-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-xs);background:var(--color-bg-tertiary);border-radius:var(--radius-md);width:fit-content}.scenario-tab{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast)}.scenario-tab:hover{color:var(--color-text-primary)}.scenario-tab.active{background:var(--color-bg-card);color:var(--color-teal-light);box-shadow:var(--shadow-sm)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--color-teal-glow);color:var(--color-teal-light);font-size:1.25rem;margin-bottom:var(--spacing-md)}.stat-label{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.stat-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--color-text-primary)}.stat-detail{font-size:.8125rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.donut-wrapper{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xl)}.donut-legend{display:flex;flex-direction:column;gap:var(--spacing-sm)}.donut-legend-item{display:flex;align-items:center;gap:var(--spacing-sm)}.donut-legend-color{width:12px;height:12px;border-radius:3px}.donut-legend-label{font-size:.875rem;color:var(--color-text-secondary)}.donut-legend-value{font-family:var(--font-mono);font-size:.875rem;font-weight:500;color:var(--color-text-primary);margin-left:auto}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.abnormal-meters-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:var(--spacing-xl);overflow:hidden}.abnormal-meters-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-bg-tertiary) 0%,var(--color-bg-card) 100%);border-bottom:1px solid var(--color-border);gap:var(--spacing-lg);flex-wrap:wrap}.abnormal-meters-title-block{flex:1;min-width:300px}.abnormal-meters-title-row{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.abnormal-meters-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.abnormal-meters-icon{font-size:1.5rem}.abnormal-meters-subtitle{color:var(--color-text-secondary);font-size:.875rem;margin-top:var(--spacing-xs)}.live-indicator.small{padding:2px 10px;font-size:.65rem;margin-left:0}.live-indicator.small .live-indicator-dot{width:6px;height:6px}.severity-counters{display:flex;gap:var(--spacing-sm)}.severity-counter{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);min-width:70px}.severity-counter.critical{background:var(--color-red-bg);border:1px solid var(--color-red-border)}.severity-counter.warning{background:var(--color-amber-bg);border:1px solid var(--color-amber-border)}.severity-counter.low{background:var(--color-green-bg);border:1px solid var(--color-green-border)}.severity-counter-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;line-height:1}.severity-counter.critical .severity-counter-value{color:var(--color-red)}.severity-counter.warning .severity-counter-value{color:var(--color-amber)}.severity-counter.low .severity-counter-value{color:var(--color-green)}.severity-counter-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-top:2px}.abnormal-meters-filters{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:var(--spacing-sm)}.filter-label{font-size:.8125rem;color:var(--color-text-secondary);font-weight:500}.filter-select{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem;color:var(--color-text-primary);font-family:var(--font-sans);cursor:pointer;min-width:160px;transition:border-color var(--transition-fast)}.filter-select:hover{border-color:var(--color-border-light)}.filter-select:focus{outline:none;border-color:var(--color-teal)}.filter-reset{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.filter-reset:hover{background:var(--color-red-bg);border-color:var(--color-red-border);color:var(--color-red)}.abnormal-meters-table-container{overflow-x:auto}.abnormal-meters-table{width:100%;border-collapse:collapse;font-size:.875rem}.abnormal-meters-table th,.abnormal-meters-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;vertical-align:top}.abnormal-meters-table th{background:var(--color-bg-secondary);font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap;position:sticky;top:0}.abnormal-meters-table td{border-bottom:1px solid var(--color-border)}.abnormal-meters-table tbody tr{transition:background var(--transition-fast)}.abnormal-meters-table tbody tr:hover{background:var(--color-bg-card-hover)}.abnormal-meters-table tbody tr:last-child td{border-bottom:none}.abnormal-meters-table tbody tr.severity-row-high{border-left:3px solid var(--color-red)}.abnormal-meters-table tbody tr.severity-row-medium{border-left:3px solid var(--color-amber)}.abnormal-meters-table tbody tr.severity-row-low{border-left:3px solid var(--color-green)}.serial-number{font-family:var(--font-mono);font-size:.75rem;background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);color:var(--color-text-secondary)}.meter-label{font-weight:500;color:var(--color-text-primary);white-space:nowrap}.project-cell{display:flex;flex-direction:column;gap:2px}.project-id-small{font-family:var(--font-mono);font-size:.65rem;color:var(--color-teal-light);font-weight:600}.project-name-small{font-size:.75rem;color:var(--color-text-secondary);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meter-type{display:inline-flex;align-items:center;gap:4px;font-size:.8125rem;color:var(--color-text-secondary);white-space:nowrap}.meter-type-icon{font-size:.9rem}.problem-description{font-size:.8125rem;color:var(--color-text-primary);max-width:200px}.last-data-cell{display:flex;flex-direction:column;gap:2px}.last-data-time{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-secondary)}.last-data-ago{font-size:.65rem;color:var(--color-text-muted)}.recommended-action{font-size:.8125rem;color:var(--color-text-secondary);font-style:italic;max-width:220px}.meter-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;border:1px solid;white-space:nowrap}.meter-status-icon{font-size:.85rem}.meter-status-label{text-transform:uppercase;letter-spacing:.03em}.severity-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-text-muted)}.no-results-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.no-results-text{font-size:1rem;color:var(--color-text-secondary)}@media (max-width: 1200px){.abnormal-meters-header{flex-direction:column}.severity-counters{width:100%;justify-content:flex-start}}@media (max-width: 768px){.abnormal-meters-filters{flex-direction:column;align-items:flex-start}.filter-group{width:100%}.filter-select{flex:1}}.floor-plan-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:var(--spacing-xl);overflow:hidden}.floor-plan-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-bg-tertiary) 0%,var(--color-bg-card) 100%);border-bottom:1px solid var(--color-border);gap:var(--spacing-lg);flex-wrap:wrap}.floor-plan-title-block{flex:1;min-width:280px}.floor-plan-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0}.floor-plan-icon{font-size:1.5rem}.floor-plan-subtitle{color:var(--color-text-secondary);font-size:.875rem;margin-top:var(--spacing-xs)}.floor-plan-legend{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.floor-plan-legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--color-text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:var(--color-bg-tertiary)}.floor-plan-legend-item .legend-dot{width:10px;height:10px;border-radius:50%}.floor-plan-legend-item.ok .legend-dot{background:var(--color-green)}.floor-plan-legend-item.warning .legend-dot{background:var(--color-amber)}.floor-plan-legend-item.overheating .legend-dot{background:var(--color-red)}.floor-plan-legend-item.underheating .legend-dot{background:#3b82f6}.floor-plan-legend-item .legend-count{font-family:var(--font-mono);font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary)}.floor-plan-floor-name{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.floor-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:500;color:var(--color-teal-light)}.floor-plan-container{padding:var(--spacing-xl);display:flex;gap:var(--spacing-xl);flex-wrap:wrap}.floor-plan-grid{flex:1;min-width:500px;display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-width: 600px){.floor-plan-grid{min-width:100%}}.floor-plan-row{display:grid;gap:var(--spacing-md)}.floor-plan-row-5{grid-template-columns:repeat(5,1fr)}.floor-plan-row-6{grid-template-columns:repeat(6,1fr)}.floor-plan-corridor{display:flex;gap:var(--spacing-md)}.floor-plan-corridor .floor-room{flex:1;min-height:80px}.floor-room{background:var(--room-status-bg, var(--color-bg-tertiary));border:2px solid var(--room-status-border, var(--color-border));border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;min-width:0}.floor-room:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--room-status-color, var(--color-border))}.floor-room:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:var(--room-status-color, var(--color-border-light))}.floor-room.selected{border-color:var(--room-status-color);box-shadow:0 0 0 3px var(--room-status-bg),0 8px 24px #0000004d}.floor-room-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.floor-room-name{font-size:.75rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.floor-room-status-icon{font-size:.875rem}.floor-room-temp{display:flex;align-items:baseline;gap:2px;margin-bottom:var(--spacing-xs)}.floor-room-temp-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--room-status-color, var(--color-text-primary));line-height:1}.floor-room-temp-unit{font-size:.875rem;color:var(--color-text-secondary)}.floor-room-range{font-size:.7rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.floor-room-heating{font-size:.7rem;font-weight:500}.floor-room-heating .heating-on{color:#f97316}.floor-room-heating .heating-off{color:#64748b}.floor-room-detail-panel{min-width:280px;max-width:320px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.floor-room-detail-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.floor-room-detail-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.floor-room-detail-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--color-text-muted);background:var(--color-bg-tertiary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.floor-room-detail-close:hover{background:var(--color-red-bg);color:var(--color-red)}.floor-room-detail-content{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.floor-room-detail-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm);background:var(--color-bg-card);border-radius:var(--radius-sm)}.floor-room-detail-label{font-size:.8125rem;color:var(--color-text-secondary)}.floor-room-detail-value{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.floor-room-detail-value.heating-active{color:#f97316}.floor-room-detail-value.heating-inactive{color:#64748b}.floor-room-detail-status{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.floor-room-detail-note{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-top:1px solid var(--color-border)}.floor-room-detail-note p{margin:0;font-size:.7rem;color:var(--color-text-muted);text-align:center}.floor-plan-footer{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-tertiary);border-top:1px solid var(--color-border)}.floor-plan-note{font-size:.8125rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-xs)}.floor-plan-future{font-size:.75rem;color:var(--color-text-muted);margin:0}@media (max-width: 1200px){.floor-plan-row-5,.floor-plan-row-6{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.floor-plan-header{flex-direction:column}.floor-plan-legend{width:100%;justify-content:flex-start}.floor-plan-container{flex-direction:column}.floor-plan-grid{min-width:100%}.floor-room-detail-panel{min-width:100%;max-width:100%}.floor-plan-row-5,.floor-plan-row-6{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.floor-plan-row-5,.floor-plan-row-6{grid-template-columns:1fr}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.meter-detail-modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .25s ease;box-shadow:0 25px 50px -12px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);background:linear-gradient(135deg,var(--color-bg-tertiary) 0%,var(--color-bg-card) 100%);border-bottom:1px solid var(--color-border);gap:var(--spacing-lg);flex-wrap:wrap}.modal-header-left{display:flex;align-items:flex-start;gap:var(--spacing-md);flex:1;min-width:0}.modal-meter-icon{font-size:2rem;flex-shrink:0}.modal-title-block{min-width:0;flex:1}.modal-title{font-size:1.375rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs);line-height:1.2}.modal-subtitle{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.modal-serial{font-family:var(--font-mono);font-size:.8125rem;background:var(--color-bg-tertiary);padding:2px 8px;border-radius:var(--radius-sm);color:var(--color-text-secondary)}.modal-location{font-size:.8125rem;color:var(--color-text-muted)}.modal-header-right{display:flex;align-items:flex-start;gap:var(--spacing-md)}.modal-badges{display:flex;gap:var(--spacing-sm)}.modal-close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.modal-close-btn:hover{background:var(--color-red-bg);border-color:var(--color-red-border);color:var(--color-red)}.modal-content{flex:1;overflow-y:auto;padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-xl)}.modal-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media (max-width: 600px){.modal-kpi-row{grid-template-columns:1fr}}.modal-kpi-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.modal-kpi-label{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.modal-kpi-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--color-text-primary);line-height:1.2}.modal-kpi-value.high{color:var(--color-red)}.modal-kpi-value.medium{color:var(--color-amber)}.modal-kpi-unit{font-size:.875rem;font-weight:400;color:var(--color-text-secondary);margin-left:4px}.modal-kpi-time{font-size:.7rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.modal-metadata{display:flex;flex-direction:column;gap:var(--spacing-sm)}.modal-meta-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem}.modal-meta-label{color:var(--color-text-muted);min-width:100px}.modal-meta-value{color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.modal-project-id{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--color-teal-light);background:var(--color-teal-glow);padding:2px 6px;border-radius:var(--radius-sm)}.modal-problem-section{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}@media (max-width: 700px){.modal-problem-section{grid-template-columns:1fr}}.modal-problem-card,.modal-action-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.modal-problem-card{border-left:3px solid var(--color-amber)}.modal-action-card{border-left:3px solid var(--color-teal)}.modal-problem-header,.modal-action-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.modal-problem-icon,.modal-action-icon{font-size:1rem}.modal-problem-title,.modal-action-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.modal-problem-text,.modal-action-text{font-size:.9375rem;color:var(--color-text-primary);line-height:1.5;margin:0}.modal-chart-section{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.modal-chart-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.modal-chart-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0}.modal-chart-description{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.granularity-tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs);background:var(--color-bg-card);border-radius:var(--radius-md)}.granularity-tab{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.granularity-tab:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.granularity-tab.active{background:var(--color-teal-glow);color:var(--color-teal-light)}.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-xl);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);gap:var(--spacing-md);flex-wrap:wrap}.modal-footer-info{display:flex;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.modal-status-legend{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8125rem;color:var(--color-text-secondary)}.modal-status-dot{width:10px;height:10px;border-radius:50%}.modal-severity-text{font-size:.8125rem;color:var(--color-text-secondary)}.modal-close-action{padding:var(--spacing-sm) var(--spacing-xl);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.modal-close-action:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-light)}.meter-chart-container{margin-top:var(--spacing-sm)}.chart-no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;height:280px;background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-md)}.chart-no-data-icon{font-size:2.5rem;margin-bottom:var(--spacing-md);opacity:.5}.chart-no-data-text{font-size:.9375rem;color:var(--color-text-muted)}.meter-chart-legend{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-top:var(--spacing-md);flex-wrap:wrap}.meter-chart-legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.75rem;color:var(--color-text-secondary)}.meter-chart-legend-line{width:20px;height:3px;border-radius:2px}.meter-chart-legend-line.dashed{background:transparent;border-bottom:2px dashed;height:0}.meter-chart-legend-band{width:20px;height:12px;border-radius:2px}.meter-chart-legend-peak{width:12px;height:12px;border-radius:50%;background:var(--color-red);border:2px solid white}.abnormal-meters-table tbody tr.clickable-row{cursor:pointer}.abnormal-meters-table tbody tr.clickable-row:hover{background:var(--color-bg-card-hover)}.abnormal-meters-table tbody tr.clickable-row:active{background:var(--color-bg-tertiary)}.abnormal-meters-table tbody tr.clickable-row td:first-child{position:relative}.abnormal-meters-table tbody tr.clickable-row:hover td:first-child:before{content:"→";position:absolute;left:4px;top:50%;transform:translateY(-50%);color:var(--color-teal-light);font-size:.875rem;opacity:.7}
