:root{--color-primary:#166177;--color-primary-dark:#0f4a5a;--color-accent:#f8722d;--color-accent-dark:#e05e1a;--color-secondary:#3de0d2;--color-text:#545454;--color-text-light:#888;--color-text-white:#fff;--color-bg:#f3f3f3;--color-surface:#fff;--color-border:#e0e0e0;--color-alarm:#f8722d;--color-alarm-bg:#fff4ef;--color-ok:#3de0d2;--color-ok-bg:#edfcfb;--color-danger:#c0392b;--color-danger-bg:#fdf2f2;--radius-card:8px;--radius-btn:4px;--radius-input:4px;--shadow-card:0 2px 8px #00000014;--shadow-modal:0 8px 32px #0000002e;--font:"Segoe UI", "Segoe UI Variable", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--sidebar-width:240px;--header-height:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:600;line-height:1.3}h1{font-size:1.75rem}h2{font-size:1.4rem}h3{font-size:1.15rem}h4{font-size:1rem}p{margin-bottom:.75rem}p:last-child{margin-bottom:0}small{color:var(--color-text-light);font-size:.85rem}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-primary);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid #ffffff1a;padding:20px 20px 16px}.sidebar-logo img{filter:brightness(0)invert();height:29px}.sidebar-tenant{color:#fff9;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #ffffff14;padding:12px 20px;font-size:.8rem}.sidebar-nav{flex:1;padding:12px 0}.sidebar-nav a{color:#fffc;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:.9rem;font-weight:400;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:flex}.sidebar-nav a:hover{color:#fff;background:#ffffff14;text-decoration:none}.sidebar-nav a.active{color:#fff;border-left-color:var(--color-accent);background:#ffffff1f;font-weight:600}.sidebar-nav .nav-icon,.sidebar-nav a svg{flex-shrink:0;width:16px;height:16px}.sidebar-footer{color:#fff9;border-top:1px solid #ffffff1a;padding:16px 20px;font-size:.85rem}.sidebar-footer a{color:#fff9;align-items:center;gap:8px;padding:6px 0;text-decoration:none;display:flex}.sidebar-footer a:hover{color:#fff;text-decoration:none}.sidebar-footer-active{font-weight:600;color:#fff!important}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:50;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{color:var(--color-text);font-size:1rem;font-weight:600}.topbar-actions{align-items:center;gap:12px;display:flex}.topbar-user{color:var(--color-text-light);align-items:center;gap:8px;font-size:.85rem;display:flex}.topbar-status{align-items:center;gap:8px;display:flex}.topbar-status-badge{border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:.75rem;font-weight:600;display:inline-flex}.topbar-badge-alarm{background:var(--color-alarm-bg);color:var(--color-alarm)}.topbar-badge-offline{background:var(--color-danger-bg);color:var(--color-danger)}.topbar-status-time{color:var(--color-text-light);background:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:.78rem;display:inline-flex}.avatar{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.page-body{flex:1;padding:24px}.card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1px solid var(--color-border)}.card-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{color:var(--color-text);font-size:.95rem;font-weight:600}.card-body{padding:20px}.card-footer{border-top:1px solid var(--color-border);border-radius:0 0 var(--radius-card) var(--radius-card);background:#fafafa;padding:12px 20px}.status-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.status-card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1px solid var(--color-border);padding:20px;transition:box-shadow .2s;position:relative;overflow:hidden}.status-card:hover{box-shadow:0 4px 16px #0000001f}.status-card.alarm{border-left:4px solid var(--color-alarm);background:var(--color-alarm-bg)}.status-card.offline{border-left:4px solid var(--color-danger);background:var(--color-danger-bg)}.status-card.ok{border-left:4px solid var(--color-ok)}.status-card.no-data{border-left:4px solid var(--color-border)}.status-card-device{color:var(--color-text-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:.8rem}.status-card-temp{color:var(--color-text);margin-bottom:8px;font-size:2rem;font-weight:700;line-height:1}.status-card-temp.alarm{color:var(--color-alarm)}.status-card-meta{color:var(--color-text-light);font-size:.78rem}.stat-row{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-box{background:var(--color-surface);border-radius:var(--radius-card);border:1px solid var(--color-border);box-shadow:var(--shadow-card);text-align:center;padding:16px 20px}.stat-box .stat-value{color:var(--color-primary);font-size:1.75rem;font-weight:700}.stat-box .stat-label{color:var(--color-text-light);margin-top:2px;font-size:.78rem}.btn{border-radius:var(--radius-btn);font-family:var(--font);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-size:.875rem;font-weight:500;line-height:1.5;text-decoration:none;transition:background .15s,border-color .15s,box-shadow .15s;display:inline-flex}.btn:hover{text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.btn-accent{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-accent:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark);color:#fff}.btn-outline{color:var(--color-primary);border-color:var(--color-primary);background:0 0}.btn-outline:hover{background:var(--color-primary);color:#fff}.btn-ghost{color:var(--color-text-light);border-color:var(--color-border);background:0 0}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover{color:#fff;background:#a93226;border-color:#a93226}.btn-sm{padding:4px 10px;font-size:.8rem}.btn-lg{padding:10px 24px;font-size:1rem}.btn:disabled,.btn.disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-label{color:var(--color-text);margin-bottom:5px;font-size:.85rem;font-weight:500;display:block}.form-control{border:1px solid var(--color-border);border-radius:var(--radius-input);width:100%;font-family:var(--font);color:var(--color-text);background:var(--color-surface);outline:none;padding:8px 12px;font-size:.875rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1661771f}.form-control:disabled{color:var(--color-text-light);background:#f5f5f5}input.form-control,select.form-control{height:37px}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}.form-hint{color:var(--color-text-light);margin-top:4px;font-size:.78rem}.form-error{color:var(--color-danger);margin-top:4px;font-size:.78rem}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-control.is-invalid{border-color:var(--color-danger)}.form-control.is-invalid:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #c0392b1f}.device-name-link{color:var(--color-text);text-decoration:none}.device-name-link:hover{color:var(--color-primary);text-decoration:none}.table-wrapper{overflow-x:auto}table.data-table{border-collapse:collapse;width:100%;font-size:.875rem}table.data-table thead tr{background:#f7f7f7}table.data-table th{text-align:left;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 14px;font-size:.78rem;font-weight:600}table.data-table td{vertical-align:middle;border-bottom:1px solid #f0f0f0;padding:11px 14px}table.data-table tbody tr:hover{background:#fafafa}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table tr.alarm-row td{background:var(--color-alarm-bg)}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-ok{background:var(--color-ok-bg);color:#0f8a7d}.badge-alarm{background:var(--color-alarm-bg);color:var(--color-alarm)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{color:var(--color-primary);background:#e8f4f8}.badge-muted{color:var(--color-text-light);background:#f0f0f0}.alert{border-radius:var(--radius-card);align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:.875rem;display:flex}.alert-success{background:var(--color-ok-bg);border-left:4px solid var(--color-ok);color:#0f7a6e}.alert-warning{background:var(--color-alarm-bg);border-left:4px solid var(--color-alarm);color:#b05010}.alert-danger{background:var(--color-danger-bg);border-left:4px solid var(--color-danger);color:var(--color-danger)}.alert-info{border-left:4px solid var(--color-primary);color:var(--color-primary);background:#e8f4f8}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-modal);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-size:1rem;font-weight:600}.modal-close{cursor:pointer;color:var(--color-text-light);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:1.2rem;line-height:1}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:10px;padding:12px 20px;display:flex}.pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;padding:16px 0;display:flex}.pg-btn{border-radius:var(--radius-btn);min-width:32px;height:32px;font-size:.85rem;font-family:var(--font);border:1px solid var(--color-border);color:var(--color-text);background:var(--color-surface);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:0 10px;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}a.pg-btn:hover{background:var(--color-bg);border-color:#ccc;text-decoration:none}.pg-btn.pg-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);cursor:default;font-weight:600}.pg-btn.disabled{color:#bbb;cursor:default;pointer-events:none;background:#fafafa;border-color:#eee}.pg-dots{height:32px;color:var(--color-text-light);justify-content:center;align-items:center;padding:0 4px;font-size:.85rem;display:inline-flex}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-bar .form-control{width:auto;min-width:140px}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.page-header-left h1{margin-bottom:2px;font-size:1.4rem;font-weight:700}.page-header-left p{color:var(--color-text-light);margin-bottom:0;font-size:.85rem}.auth-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-modal);border:1px solid var(--color-border);width:100%;max-width:400px;padding:40px 36px}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo img{height:44px;margin:0 auto}.auth-title{text-align:center;margin-bottom:6px;font-size:1.2rem;font-weight:700}.auth-subtitle{text-align:center;color:var(--color-text-light);margin-bottom:28px;font-size:.85rem}.landing-nav{border-bottom:1px solid var(--color-border);background:#fff;justify-content:space-between;align-items:center;height:60px;padding:0 32px;display:flex}.landing-nav-logo img{height:32px}.landing-nav-links{align-items:center;gap:24px;font-size:.9rem;display:flex}.landing-hero{background:linear-gradient(135deg, var(--color-primary) 0%, #0f4a5a 100%);color:#fff;text-align:center;padding:80px 24px}.landing-hero h1{color:#fff;margin-bottom:16px;font-size:2.5rem;font-weight:800}.landing-hero p{color:#ffffffd9;max-width:560px;margin:0 auto 28px;font-size:1.1rem}.landing-section{max-width:1100px;margin:0 auto;padding:64px 24px}.section-title{text-align:center;margin-bottom:8px;font-size:1.6rem;font-weight:700}.section-subtitle{text-align:center;color:var(--color-text-light);margin-bottom:0;font-size:.95rem}.feature-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-top:40px;display:grid}.feature-card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1px solid var(--color-border);padding:28px 24px}.feature-card .feature-icon{background:var(--color-ok-bg);width:44px;height:44px;color:var(--color-primary);border-radius:10px;justify-content:center;align-items:center;margin-bottom:16px;font-size:1.4rem;display:flex}.feature-card h3{margin-bottom:8px;font-size:1rem}.feature-card p{color:var(--color-text-light);margin:0;font-size:.875rem}.pricing-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;margin-top:40px;display:grid}.pricing-card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1px solid var(--color-border);text-align:center;padding:32px 28px}.pricing-card.featured{border-color:var(--color-primary);box-shadow:0 4px 20px #16617726}.pricing-card .plan-name{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-light);font-size:.85rem;font-weight:600}.pricing-card .price{color:var(--color-primary);margin:12px 0;font-size:2.2rem;font-weight:800}.pricing-card .price sup{vertical-align:super;font-size:1rem}.pricing-card .price span{color:var(--color-text-light);font-size:.9rem;font-weight:400}.pricing-features{text-align:left;margin:20px 0;list-style:none}.pricing-features li{border-bottom:1px solid #f5f5f5;padding:6px 0;font-size:.875rem}.pricing-features li:before{content:"✓ ";color:var(--color-primary);font-weight:700}.landing-footer{background:var(--color-primary);color:#ffffffb3;text-align:center;padding:32px 24px;font-size:.85rem}.landing-footer a{color:#ffffffb3}.landing-footer a:hover{color:#fff}.d-flex{display:flex}.d-none{display:none}.d-block{display:block}.align-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-light)}.text-sm{font-size:.85rem}.text-xs{font-size:.78rem}.w-100{width:100%}.fw-600{font-weight:600}.divider{border:none;border-top:1px solid var(--color-border);margin:20px 0}.pw-wrap{position:relative}.pw-wrap .form-control{padding-right:40px}.pw-toggle{cursor:pointer;color:var(--color-text-light);background:0 0;border:none;align-items:center;padding:4px;transition:color .15s;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.pw-toggle:hover{color:var(--color-text)}.pw-toggle svg{display:block}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.breadcrumb{color:var(--color-text-light);align-items:center;gap:6px;margin-bottom:16px;font-size:.8rem;display:flex}.breadcrumb a{color:var(--color-primary)}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .sep{color:var(--color-border)}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-ok{background:var(--color-ok)}.dot-alarm{background:var(--color-alarm)}.dot-muted{background:#ccc}@media (width<=900px){:root{--sidebar-width:200px}}@media (width<=768px){.sidebar{display:none}.main-content{margin-left:0}.form-row{grid-template-columns:1fr}.stat-row{grid-template-columns:repeat(2,1fr)}.status-grid{grid-template-columns:1fr 1fr}}.notif-wrap{display:inline-block;position:relative}.notif-btn{cursor:pointer;border-radius:var(--radius-btn);color:var(--color-text-light);background:0 0;border:none;padding:4px 6px;font-size:1rem;line-height:1;transition:background .15s,color .15s}.notif-btn:hover{background:var(--color-bg);color:var(--color-primary)}.notif-btn.muted{color:#ccc}.notif-btn.active{color:var(--color-accent)}.notif-dropdown{z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-modal);min-width:190px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.notif-dropdown-header{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light);border-bottom:1px solid var(--color-border);padding:8px 14px;font-size:.75rem;font-weight:600}.notif-option{cursor:pointer;color:var(--color-text);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 14px;font-size:.88rem;transition:background .12s;display:flex}.notif-option:hover{background:var(--color-bg)}.notif-option.selected{color:var(--color-primary);font-weight:600}.notif-option .notif-icon{text-align:center;width:18px;font-size:1rem}.notif-option .notif-check{color:var(--color-primary);margin-left:auto;font-size:.85rem}.btn-acknowledge{border:1px solid var(--color-alarm);color:var(--color-alarm);border-radius:var(--radius-btn);cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--font);background:0 0;align-items:center;gap:5px;padding:4px 10px;text-decoration:none;transition:background .15s,color .15s;display:inline-flex}.btn-acknowledge:hover{background:var(--color-alarm);color:#fff}.btn-acknowledge.acknowledged{border-color:var(--color-text-light);color:var(--color-text-light);cursor:default}.btn-acknowledge.acknowledged:hover{color:var(--color-text-light);background:0 0}@media print{.sidebar,.topbar,.no-print,.filter-bar,.btn{display:none!important}.main-content{margin-left:0}.page-body{padding:0}body{background:#fff;font-size:12px}.card{box-shadow:none;page-break-inside:avoid;border:1px solid #ddd}}
