:root{--bg:#0b0d11;--panel:#14181f;--panel-2:#1b2129;--line:#242b35;--fg:#e8edf2;--mute:#8a93a1;--ok:#34c759;--warn:#ffcc00;--bad:#ff453a;--accent:#1f6feb}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--fg);font:15px/1.45 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}
#reload-banner{position:fixed;left:0;right:0;bottom:0;background:var(--accent);color:#fff;padding:.6rem 1rem;display:flex;align-items:center;justify-content:space-between;font:14px system-ui,sans-serif;z-index:100;box-shadow:0 -4px 12px rgba(0,0,0,.4)}
#reload-banner button{background:#fff;color:var(--accent);border:0;padding:.35rem .9rem;border-radius:6px;font-weight:600;cursor:pointer}

.topbar{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;border-bottom:1px solid var(--line);background:#10141a;position:sticky;top:0;z-index:10}
.brand{font-weight:700;letter-spacing:.08em}
.meta{margin-left:auto;color:var(--mute);font-size:13px}
.sep{margin:0 .3rem}
main{padding:1rem;max-width:1100px;margin:0 auto}
.status{padding:.6rem .8rem;background:var(--panel);border-radius:8px}
.status.error{background:#3a1a1a;color:#ffb3ad}

.pumps{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.8rem;margin:1rem 0}
.pump{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:.9rem}
.pump h3{margin:0 0 .4rem;font-size:1.05rem}
.pump.inactive{opacity:.55}
.pump .badge{font-size:11px;padding:2px 7px;border-radius:99px;background:var(--accent);margin-left:.4rem;vertical-align:middle}
.pump.inactive .badge{background:#444}

.kv{display:grid;grid-template-columns:auto 1fr;gap:.15rem .8rem;font-size:13px;margin-top:.3rem}
.kv dt{color:var(--mute)}
.kv dd{margin:0}

.ticket-header{display:flex;align-items:center;gap:.8rem;margin:1.2rem 0 .4rem;flex-wrap:wrap}
.ticket-header h2{font-size:1.05rem;margin:0}
.filters{display:flex;gap:.4rem;margin-left:auto}
.filter-pill{background:var(--panel-2);border:1px solid var(--line);color:var(--fg);padding:.3rem .8rem;border-radius:99px;font-size:13px;cursor:pointer}
.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
.filter-pill span{margin-left:.3rem;color:var(--mute);font-weight:600}
.filter-pill.active span{color:#bcd5ff}

#ticket-list{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
#ticket-list li{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:.6rem .8rem}
#ticket-list li.has-alarm{border-color:var(--bad)}
.ticket-summary{cursor:pointer}
.ticket-summary:hover .bol{color:#79b8ff}
.ticket-line-1{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.25rem}
.ticket-line-2{display:flex;justify-content:space-between;align-items:center;gap:.6rem;color:var(--fg);font-size:13px;flex-wrap:wrap}
#ticket-list .bol{font-weight:600;font-size:15px}
#ticket-list .pump{font-size:12px;background:var(--panel-2);padding:1px 6px;border-radius:4px;color:var(--mute)}
#ticket-list .when{color:var(--mute);font-size:12px}
.alarm-badge{background:var(--bad);color:#fff;font-size:11px;padding:2px 7px;border-radius:4px;font-weight:600;letter-spacing:.05em}
.review-badge{background:var(--ok);color:#000;font-size:11px;padding:2px 7px;border-radius:4px;font-weight:600}
.review-badge.review-manager_reviewed{background:#34c759}
.review-badge.review-exported{background:var(--accent);color:#fff}

.ticket-detail{margin-top:.7rem;padding-top:.6rem;border-top:1px solid var(--line)}
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem}
.detail-group h4{font-size:12px;color:var(--mute);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .25rem}
.detail-group.alarms h4{color:var(--bad)}
.detail-group .kv{font-size:13px;grid-template-columns:auto 1fr;gap:.1rem .6rem}
.detail-group .kv dt{color:var(--mute)}
.detail-group ul{margin:.2rem 0 0;padding-left:1.1rem;font-size:13px}
.detail-group .muted{color:var(--mute);font-size:12px;margin:.2rem 0}
.raw{margin-top:.7rem;font-size:12px}
.raw summary{cursor:pointer;color:var(--mute)}
.raw pre{background:#0a0d12;border:1px solid var(--line);border-radius:6px;padding:.6rem;overflow:auto;max-height:300px;font-size:11px;line-height:1.4}

/* Phase 1 — bottom sheet + ticket actions */
.ticket-actions{display:flex;gap:.6rem;padding:.8rem;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--panel);justify-content:flex-end}
.btn-primary{background:var(--accent);color:#fff;border:0;padding:.7rem 1.1rem;border-radius:8px;font-weight:600;min-height:44px;cursor:pointer}
.btn-secondary{background:transparent;color:var(--mute);border:1px solid var(--line);padding:.7rem 1.1rem;border-radius:8px;min-height:44px;cursor:pointer}
.review-badge{font-size:11px;padding:2px 7px;border-radius:99px;margin-left:.3rem;vertical-align:middle;background:#1c2c1c;color:#7ddf7d}
.review-badge.review-manager_reviewed{background:#1a2640;color:#9cc1ff}
.sheet{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;justify-content:flex-end}
.sheet[hidden]{display:none}
.sheet-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);opacity:0;transition:opacity .2s ease}
.sheet.open .sheet-backdrop{opacity:1}
.sheet-panel{position:relative;background:var(--panel);border-top:1px solid var(--line);border-radius:14px 14px 0 0;padding:1rem 1rem 1.2rem;transform:translateY(100%);transition:transform .22s ease;display:flex;flex-direction:column;gap:.6rem;max-height:90vh;overflow-y:auto}
.sheet.open .sheet-panel{transform:translateY(0)}
.sheet-panel h3{margin:0 0 .3rem}
.sheet-hint{color:var(--mute);font-size:13px;margin:0 0 .4rem}
.sheet-panel label{display:flex;flex-direction:column;gap:.25rem;font-size:13px;color:var(--mute)}
.sheet-panel input{background:var(--panel-2);border:1px solid var(--line);color:var(--fg);border-radius:8px;padding:.7rem .8rem;font-size:16px;min-height:44px}
.sheet-err{background:#3a1a1a;color:#ffb3ad;padding:.5rem .7rem;border-radius:8px;font-size:13px}
.sheet-actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:.4rem}
