@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Syne:wght@600;700&display=swap";.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width, 240px);background:var(--card-bg, #fff);border-right:1px solid var(--border-color, #e2e8f0);display:flex;flex-direction:column;z-index:100;transition:width .25s ease,transform .25s ease;overflow:hidden}.sidebar-collapsed{width:var(--sidebar-collapsed-width, 64px)}.sidebar-overlay{display:none}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-color, #e2e8f0);min-height:var(--topbar-height, 64px)}.sidebar-logo{display:flex;align-items:center;gap:.6rem;overflow:hidden}.sidebar-logo-icon{flex-shrink:0}.sidebar-title{font-family:var(--font-display, "Syne", sans-serif);font-weight:700;font-size:1.1rem;color:var(--text-primary);white-space:nowrap}.collapse-toggle{background:none;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);flex-shrink:0;transition:background .15s,color .15s}.collapse-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-menu{list-style:none;padding:.5rem;flex:1;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.65rem .75rem;border:none;border-radius:var(--radius-md, 8px);background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s;text-align:left;white-space:nowrap}.sidebar-item:hover{background:var(--bg-secondary, #f1f5f9);color:var(--text-primary)}.sidebar-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:var(--primary, #667eea);font-weight:600}.sidebar-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.sidebar{transform:translate(0);width:var(--sidebar-width, 240px);box-shadow:var(--shadow-lg)}.sidebar-collapsed{transform:translate(-100%);width:var(--sidebar-width, 240px)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99;animation:fade-in .2s ease}}.topbar{position:fixed;top:0;right:0;left:var(--sidebar-width, 240px);height:var(--topbar-height, 64px);background:var(--card-bg, #fff);border-bottom:1px solid var(--border-color, #e2e8f0);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:90;transition:left .25s ease}.admin-main.collapsed .topbar{left:var(--sidebar-collapsed-width, 64px)}.topbar-left{display:flex;align-items:center;gap:1rem}.topbar-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.topbar-right{display:flex;align-items:center;gap:1rem}.topbar-user{font-size:.875rem;color:var(--text-secondary);font-weight:500}.topbar-menu-btn{display:none;background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:background .15s}.topbar-menu-btn:hover{background:var(--bg-secondary)}@media (max-width: 768px){.topbar-menu-btn{display:flex}.topbar-user{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-card{background:var(--card-bg, #fff);border-radius:var(--radius-lg, 12px);padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #00000026;animation:scale-in .3s ease}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.login-subtitle{color:var(--text-muted);font-size:.9rem}.login-error{background:var(--danger-bg, #fee2e2);color:var(--danger-text, #991b1b);padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:1.5rem;border:1px solid rgba(239,68,68,.2)}.login-form .form-group{margin-bottom:1.25rem}.login-btn{width:100%;padding:.75rem;font-size:1rem;margin-top:.5rem}.dash-page{animation:fade-in-down .3s ease both}.dash-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}@media (max-width: 1100px){.dash-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.dash-cards{grid-template-columns:1fr}}.dash-card{display:flex;align-items:center;gap:1rem;cursor:pointer;animation:card-enter .4s cubic-bezier(.34,1.2,.64,1) both}.dash-card:nth-child(2){animation-delay:.05s}.dash-card:nth-child(3){animation-delay:.1s}.dash-card:nth-child(4){animation-delay:.15s}.dash-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000014}.dash-card-warning{border-color:var(--warning)}.dash-card-danger{border-color:var(--danger)}.dash-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.dash-icon-blue{background:var(--info-bg);color:var(--info)}.dash-icon-green{background:var(--success-bg);color:var(--success)}.dash-icon-amber{background:var(--warning-bg);color:var(--warning)}.dash-icon-red{background:var(--danger-bg);color:var(--danger)}.section-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.dash-device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.dash-device-card{padding:1.25rem}.dash-device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.dash-device-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.dash-device-reading{display:flex;flex-direction:column;gap:.25rem}.dash-reading-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.dash-reading-conf{font-size:.8rem;font-weight:500}.upload-page{animation:fade-in-down .3s ease both}.upload-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media (max-width: 900px){.upload-layout{grid-template-columns:1fr}}.upload-card,.upload-result-card{min-height:400px}.upload-dropzone{border:2px dashed var(--border-color, #e2e8f0);border-radius:var(--radius-md);padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;min-height:200px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.upload-dropzone:hover{border-color:var(--primary);background:#667eea05}.upload-dropzone.has-preview{cursor:default;padding:.5rem}.upload-preview-img{max-width:100%;max-height:300px;border-radius:var(--radius-sm);object-fit:contain}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted)}.upload-icon{font-size:2.5rem;opacity:.6}.upload-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.upload-processing{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 0}.upload-empty-result{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.upload-empty-icon{font-size:3rem;opacity:.3;margin-bottom:.5rem}.upload-result{animation:fade-in .3s ease}.result-main{text-align:center;padding:1.5rem 0;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.result-value-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.result-value{font-size:2.5rem;font-weight:700;color:var(--text-primary);font-family:var(--font-code)}.result-unit{font-size:1rem;font-weight:500;color:var(--text-muted);margin-left:.5rem}.result-details{display:flex;flex-direction:column;gap:.75rem}.result-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.result-row>span:first-child{color:var(--text-secondary);font-weight:500}.result-flags{display:flex;gap:.35rem;flex-wrap:wrap}.result-candidates{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-color)}.result-candidate{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0;font-size:.85rem}.upload-error-result{padding:2rem;text-align:center}.readings-page{animation:fade-in-down .3s ease both}.readings-filters{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.readings-date-range{display:flex;align-items:center;gap:.5rem}.readings-filter-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.readings-date-input{height:34px;padding:0 .5rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.825rem;font-family:inherit;color:var(--text-primary);background:var(--card-bg);transition:border-color .2s}.readings-date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.readings-suspect-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap}.readings-suspect-toggle input[type=checkbox]{width:auto;padding:0;margin:0}.readings-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}@media (max-width: 768px){.readings-filters{flex-direction:column;align-items:flex-start}.readings-date-range{flex-wrap:wrap}}.devices-page{animation:fade-in-down .3s ease both}.devices-mqtt-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:1.5rem 0 1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.devices-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.settings-page{animation:fade-in-down .3s ease both}.settings-card{max-width:480px}.settings-form{display:flex;flex-direction:column}.settings-success{background:var(--success-bg);color:var(--success-text);padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;border:1px solid rgba(16,185,129,.2)}.users-page{animation:fade-in-down .3s ease both}.users-role-select{padding:4px 8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.8rem;background:var(--card-bg);cursor:pointer}.tenants-page{animation:fade-in-down .3s ease both}.tenants-period-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 600px){.tenants-period-row{grid-template-columns:1fr}}:root{--font-body: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Syne", sans-serif;--font-code: source-code-pro, Menlo, Monaco, "Courier New", monospace;--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--card-bg: #ffffff;--card-bg-secondary: #f8fafc;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--input-border: #e0e0e0;--input-bg: #fafafa;--primary: #667eea;--primary-dark: #764ba2;--success: #10b981;--success-bg: #d1fae5;--success-text: #065f46;--warning: #f59e0b;--warning-bg: #fef3c7;--warning-text: #92400e;--danger: #ef4444;--danger-bg: #fee2e2;--danger-text: #991b1b;--info: #3b82f6;--info-bg: #dbeafe;--info-text: #1e40af;--sidebar-width: 240px;--sidebar-collapsed-width: 64px;--topbar-height: 64px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-card: 0 1px 3px rgba(0, 0, 0, .08);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 14px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body, "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary, #f8fafc);color:var(--text-primary, #1e293b)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display, "Syne", sans-serif)}#root{min-height:100vh}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary, #f8fafc)}.admin-main{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width, 240px);transition:margin-left .25s ease}.admin-main.collapsed{margin-left:var(--sidebar-collapsed-width, 64px)}.admin-content{flex:1;padding:2rem;padding-top:calc(var(--topbar-height, 64px) + 2rem);max-width:1400px;width:100%}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;animation:fade-in-down .25s cubic-bezier(.4,0,.2,1) both}.page-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.page-header p{margin:.25rem 0 0;color:var(--text-secondary);font-size:.875rem}.header-actions{display:flex;gap:.75rem;align-items:center;flex:1;justify-content:flex-end}.search-container{flex:1;max-width:360px;position:relative}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);font-size:1rem;color:var(--text-muted)}.search-input{width:100%;height:38px;padding:0 1rem 0 2.5rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;background:var(--card-bg);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a}.form-group{margin-bottom:1.5rem}.form-label,.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:14px}.form-input,.form-group input,.form-group select,.form-group textarea{width:100%;height:48px;padding:12px 16px;font-size:15px;border:2px solid var(--input-border);border-radius:var(--radius-sm);background-color:var(--input-bg);color:var(--text-primary);transition:border-color .2s,background-color .2s,box-shadow .2s;font-family:inherit}.form-group textarea{height:auto;min-height:80px}.form-input:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);background-color:var(--card-bg);box-shadow:0 0 0 3px #667eea1a}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.form-error{font-size:13px;color:var(--danger);margin-top:4px}.btn{padding:.55rem 1.1rem;border:1px solid transparent;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;line-height:1.4;cursor:pointer;transition:background-color .2s,box-shadow .2s,transform .1s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--card-bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--text-muted)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-icon{padding:.4rem;min-width:32px;min-height:32px}.table-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{padding:.875rem 1rem;background:var(--bg-primary);font-weight:600;color:var(--text-secondary);text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th:hover{color:var(--text-primary)}.data-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-primary)}.table-actions{display:flex;gap:.5rem}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:9999px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.badge-info{background:var(--info-bg);color:var(--info-text)}.badge-neutral{background:#e2e8f0;color:#475569}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-card);transition:box-shadow .3s,transform .25s}.card:hover{box-shadow:var(--shadow-md)}.card-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.03em}.card-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.card-sub{font-size:.8rem;color:var(--text-muted);margin-top:.35rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fade-in .2s ease}.modal{background:var(--card-bg);border-radius:var(--radius-lg);width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:scale-in .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state svg{width:64px;height:64px;margin-bottom:1rem;opacity:.4}.empty-state h3{font-size:1.1rem;color:var(--text-secondary);margin-bottom:.5rem}.empty-state p{font-size:.875rem}.loading-container{display:flex;align-items:center;justify-content:center;padding:4rem}.spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes card-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-mono{font-family:var(--font-code)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.flex{display:flex}.items-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}@media (max-width: 768px){.admin-main,.admin-main.collapsed{margin-left:0}.topbar{left:0!important}.admin-content{padding:1rem;padding-top:calc(var(--topbar-height, 64px) + 1rem)}.page-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;flex-wrap:wrap}.search-container{max-width:100%}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.6rem .5rem}.modal{width:95%;max-height:90vh}}
