:root{--ink: #0e1410;--paper: #f3efe6;--paper-2: #e8e2d3;--accent: #c14a1a;--green: #2d5a3d;--warn-bg: #f5e6c8;--warn-fg: #5a3d00;--alert-bg: #f5d0c0;--alert-fg: #6d1a00;--muted: #6a665d;--border: rgba(0, 0, 0, .1);--radius: 6px;--nav-h: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--paper);color:var(--ink);font-size:15px}button{cursor:pointer;border:none;background:none;font:inherit}select,input{font:inherit}a{color:var(--accent);text-decoration:none}.app{display:flex;flex-direction:column;height:100%}.nav{height:var(--nav-h);background:var(--ink);color:#f3efe6;display:flex;align-items:center;padding:0 24px;gap:32px;flex-shrink:0}.nav__brand{font-weight:700;font-size:16px;letter-spacing:-.01em}.nav__links{display:flex;gap:4px}.nav__link{color:#b9a378;font-size:14px;padding:6px 12px;border-radius:var(--radius);text-decoration:none}.nav__link--active,.nav__link:hover{background:#ffffff1a;color:#f3efe6}.main{flex:1;overflow-y:auto}.page{max-width:1100px;margin:0 auto;padding:28px 24px}.page__header{margin-bottom:24px}.page__title{font-size:28px;font-weight:700;letter-spacing:-.02em}.page__sub{color:var(--muted);font-size:14px;margin-top:4px}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}table{width:100%;border-collapse:collapse;background:#fff;min-width:600px}thead{background:var(--ink);color:#f3efe6}th{font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:500;text-align:left;padding:10px 14px}td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}.table-row:last-child td{border-bottom:none}.table-row:hover td{background:#faf8f4}.table-row.row--alert td{border-left:3px solid var(--accent)}.table-row.row--warn td{border-left:3px solid #b8924e}.table-row.row--ok td{border-left:3px solid var(--green)}.table-row.row--p1 td{border-left:3px solid var(--accent)}.table-row.row--p2 td{border-left:3px solid #b8924e}.table-row.row--p3 td{border-left:3px solid #6a665d}.num{text-align:right}.status-pill{font-size:10px;font-family:monospace;font-weight:700;padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.08em}.status-pill--ok{background:#d1e8d8;color:#1a3d24}.status-pill--warn{background:var(--warn-bg);color:var(--warn-fg)}.status-pill--alert{background:var(--alert-bg);color:var(--alert-fg)}.alert-badge{font-size:11px;font-family:monospace;font-weight:600;padding:2px 8px;border-radius:10px}.alert-badge--p1{background:var(--alert-bg);color:var(--alert-fg)}.alert-badge--p2{background:var(--warn-bg);color:var(--warn-fg)}.alert-badge--p3,.alert-badge--p4{background:#e8e2d3;color:var(--muted)}.sensor-dot{display:inline-block;border-radius:50%;flex-shrink:0}.sensor-dot--ok{background:#3a9b5c}.sensor-dot--leak_detected{background:var(--accent)}.sensor-dot--offline{background:#999}.sensor-dot--low_battery{background:#b8924e}.sensor-dot--unprovisioned,.sensor-dot--retired{background:#ccc}.floor-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.floor-label{font-family:monospace;font-size:12px;color:var(--muted);width:52px;flex-shrink:0}.floor-units{display:flex;gap:6px;flex-wrap:wrap}.unit-cell{width:52px;height:52px;border-radius:var(--radius);font-family:monospace;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}.unit-cell--ok{background:#d1e8d8;color:#1a3d24}.unit-cell--warn{background:var(--warn-bg);color:var(--warn-fg)}.unit-cell--alert{background:var(--alert-bg);color:var(--alert-fg)}.unit-cell--sm{display:inline-flex;width:14px;height:14px;font-size:0;vertical-align:middle}.legend{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);margin-top:16px;flex-wrap:wrap}.filter-bar{display:flex;gap:6px;margin-bottom:16px}.filter-btn{padding:6px 14px;border-radius:20px;font-size:13px;background:#fff;border:1px solid var(--border)}.filter-btn--active{background:var(--ink);color:#f3efe6;border-color:var(--ink)}.card-section{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.section-heading{font-size:14px;font-weight:600;margin-bottom:12px;letter-spacing:-.01em}.sensor-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.sensor-row:last-child{border-bottom:none}.sensor-row__info{flex:1;display:flex;flex-direction:column;gap:2px}.sensor-row__meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:12px}.alert-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.alert-row:last-child{border-bottom:none}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-family:monospace}.detail-value{font-size:15px;display:flex;align-items:center;gap:6px}.action-btns{display:flex;gap:6px}.action-btn{font-size:12px;padding:4px 10px;border:1px solid var(--border);border-radius:4px;background:#fff}.action-btn:hover{background:var(--paper-2)}.action-btn--resolve{border-color:var(--green);color:var(--green)}.report-controls{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.field-group{display:flex;flex-direction:column;gap:4px}.field-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-family:monospace}.field-select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:#fff}.btn-primary{padding:10px 20px;background:var(--ink);color:#f3efe6;border-radius:var(--radius);font-size:14px;font-weight:600}.btn-primary:hover{background:#2a3530}.report-list{padding-left:20px;display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--muted)}.muted{color:var(--muted);font-size:13px}.mono{font-family:monospace;font-size:12px}.warn{color:var(--warn-fg);font-weight:600}.alert{color:var(--alert-fg);font-weight:600}.error{color:var(--accent);font-size:13px}.login-shell{height:100%;display:flex;align-items:center;justify-content:center;background:var(--paper)}.login-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}.login-title{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.login-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;margin-bottom:12px}.nav__spacer{flex:1}.nav__acting{display:flex;align-items:center;gap:6px;font-size:12px;color:#b9a378;margin-right:16px}.nav__acting-label{font-family:monospace}.nav__acting-select{background:#ffffff14;color:#f3efe6;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:4px 6px;font-size:13px}.nav__user{display:flex;align-items:center;gap:12px}.nav__user-email{font-size:12px;color:#b9a378;font-family:monospace}.nav__signout{color:#b9a378;font-size:13px;padding:4px 10px;border-radius:4px}.nav__signout:hover{color:#f3efe6;background:#ffffff1a}.back-btn{color:var(--muted);font-size:14px;margin-bottom:12px;display:inline-block}.back-btn:hover{color:var(--ink)}.link-btn{color:var(--accent);font-size:14px;text-decoration:underline;text-underline-offset:2px}.warn{color:#7a5000}.alert{color:var(--alert-fg)}.section-title{font-size:14px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.events-table{width:100%;border-collapse:collapse;font-size:13px}.events-table th{text-align:left;color:var(--muted);font-weight:500;padding:4px 8px 8px 0;border-bottom:1px solid var(--border)}.events-table td{padding:6px 8px 6px 0;border-bottom:1px solid var(--border);vertical-align:top}.events-table td.mono{font-family:var(--mono);font-size:12px}.events-table tr:last-child td{border-bottom:none}
