*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--fc-purple:#534ab7;--fc-purple-light:#eeedfe;--fc-purple-mid:#afa9ec;--green:#1d9e75;--green-light:#e1f5ee;--amber:#ef9f27;--amber-light:#faeeda;--amber-dark:#854f0b;--red:#d85a30}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color:#1a1a1a;background:#f5f5f4;-webkit-font-smoothing:antialiased}button{cursor:pointer}button,input,select,textarea{font-family:inherit}textarea{resize:vertical}.app{min-height:100vh;max-width:480px;margin:0 auto}.app,.topbar{background:#fff}.topbar{padding:12px 14px;border-bottom:.5px solid #e5e5e3;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar-title{font-size:13px;font-weight:600;color:#111}.topbar-sub{font-size:11px;color:#888;margin-top:1px}.status-badge{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--green)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}.status-dot.down{background:var(--red)}.main-nav{display:flex;background:#fff;border-bottom:.5px solid #e5e5e3;overflow-x:auto;scrollbar-width:none}.main-nav::-webkit-scrollbar{display:none}.nav-tab{font-size:12px;padding:10px 14px;color:#888;background:none;border:none;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0;transition:color .15s}.nav-tab.active{color:var(--fc-purple);border-bottom-color:var(--fc-purple);font-weight:500}.section-header{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:.5px solid #e5e5e3}.section-label{font-size:12px;font-weight:500;color:#666}.btn-outline{font-size:11px;color:var(--fc-purple);padding:4px 10px;border:.5px solid var(--fc-purple-mid);border-radius:20px;background:#fff}.btn-outline:hover{background:var(--fc-purple-light)}.metric-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1px;gap:1px;background:#e5e5e3}.metric{background:#fff;padding:14px}.metric-label{font-size:11px;color:#888;margin-bottom:4px}.metric-val{font-size:22px;font-weight:600;color:#111;line-height:1.1}.metric-delta{font-size:11px;color:var(--green);margin-top:3px}.metric-delta.neutral{color:#999}.divider{height:6px;background:#f5f5f4;border-top:.5px solid #e5e5e3;border-bottom:.5px solid #e5e5e3}.chart-wrap{padding:14px}.chart-title{font-size:11px;font-weight:500;color:#888;margin-bottom:10px}.source-list{padding:14px;display:flex;flex-direction:column;gap:8px}.source-row{display:flex;align-items:center;gap:8px}.source-name{font-size:12px;color:#333;width:90px;flex-shrink:0}.source-track{flex:1 1;height:5px;background:#f0f0ee;border-radius:3px;overflow:hidden}.source-fill{height:100%;border-radius:3px;background:var(--fc-purple)}.source-pct{font-size:11px;color:#888;width:28px;text-align:right}.pill{font-size:10px;padding:2px 8px;border-radius:10px;display:inline-flex;align-items:center;gap:4px}.pill-live{background:var(--green-light);color:#0f6e56}.pill-draft{background:var(--amber-light);color:var(--amber-dark)}.pill-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.coll-pills{display:flex;gap:6px;padding:10px 14px;border-bottom:.5px solid #e5e5e3;overflow-x:auto;scrollbar-width:none}.coll-pills::-webkit-scrollbar{display:none}.cpill{font-size:12px;padding:5px 12px;border-radius:20px;border:.5px solid #ddd;color:#666;background:#fff;white-space:nowrap;flex-shrink:0}.cpill.active{background:var(--fc-purple);color:#fff;border-color:var(--fc-purple)}.list-item{padding:12px 14px;border-bottom:.5px solid #e5e5e3;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px}.list-item:hover{background:#fafaf9}.list-item:last-child{border-bottom:none}.item-name{font-size:13px;font-weight:500;color:#111}.item-meta{font-size:11px;color:#aaa;margin-top:2px}.chevron{color:#ccc;flex-shrink:0}.editor-topbar{padding:10px 14px;gap:10px;border-bottom:.5px solid #e5e5e3;position:-webkit-sticky;position:sticky;top:58px;z-index:9}.btn-back,.editor-topbar{display:flex;align-items:center;background:#fff}.btn-back{font-size:12px;color:var(--fc-purple);gap:4px;padding:4px 8px;border:.5px solid var(--fc-purple-mid);border-radius:6px;flex-shrink:0}.editor-topbar-title{font-size:13px;font-weight:500;color:#111;flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unsaved-bar{padding:7px 14px;background:var(--amber-light);border-bottom:.5px solid #e5e5e3;font-size:11px;color:var(--amber-dark);display:flex;align-items:center;gap:5px}.unsaved-dot{width:5px;height:5px;border-radius:50%;background:var(--amber);flex-shrink:0}.editor-body{padding:14px}.field{margin-bottom:14px}.field-label{font-size:11px;font-weight:500;color:#666;margin-bottom:5px;display:flex;align-items:center;gap:6px}.locked-badge{font-size:10px;background:#f0f0ee;color:#aaa;padding:1px 6px;border-radius:4px}.field input,.field select,.field textarea{width:100%;font-size:13px;padding:8px 10px;border:.5px solid #ddd;border-radius:8px;background:#fff;color:#111;outline:none}.field input:focus,.field textarea:focus{border-color:var(--fc-purple)}.field input[readonly]{background:#f5f5f4;color:#aaa;cursor:not-allowed}.field textarea{min-height:80px;line-height:1.5}.field-row-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.rt-bar{display:flex;gap:3px;padding:5px 8px;background:#f5f5f4;border:.5px solid #ddd;border-bottom:none;border-radius:8px 8px 0 0}.rt-btn{font-size:12px;padding:3px 7px;border-radius:4px;color:#666;background:transparent;border:none}.rt-btn.on,.rt-btn:hover{background:#fff;color:#111}.rt-sep{width:.5px;background:#ddd;margin:2px 3px}.rt-area{width:100%;font-size:13px;padding:8px 10px;border:.5px solid #ddd;border-top:none;border-radius:0 0 8px 8px;background:#fff;color:#111;outline:none;min-height:100px;line-height:1.5}.rt-area:focus{border-color:var(--fc-purple)}.img-upload{border:.5px dashed #ddd;border-radius:8px;padding:12px;gap:10px;background:#fafaf9;cursor:pointer}.img-thumb,.img-upload{display:flex;align-items:center}.img-thumb{width:44px;height:44px;border-radius:6px;background:var(--fc-purple-light);justify-content:center;flex-shrink:0}.img-filename{font-size:12px;font-weight:500;color:#111}.img-meta{font-size:11px;color:#888;margin-top:2px}.img-change{font-size:11px;color:var(--fc-purple);margin-top:4px}.action-bar{padding:12px 14px;border-top:.5px solid #e5e5e3;display:flex;gap:8px;background:#fff;position:-webkit-sticky;position:sticky;bottom:0}.btn-save{flex:1 1;font-size:13px;padding:9px;border:.5px solid #ddd;border-radius:8px;background:#fff;color:#333;text-align:center}.btn-save:hover{background:#f5f5f4}.btn-publish{flex:2 1;font-size:13px;font-weight:500;padding:9px;border:none;border-radius:8px;background:var(--fc-purple);color:#fff;text-align:center}.btn-publish:hover{background:#3c3489}.btn-publish:disabled{opacity:.6;cursor:not-allowed}.sub-row{padding:12px 14px;border-bottom:.5px solid #e5e5e3}.sub-row:last-child{border-bottom:none}.sub-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.sub-name{font-size:13px;font-weight:500;color:#111}.sub-time{font-size:11px;color:#aaa}.sub-form-tag{display:inline-block;font-size:10px;background:var(--fc-purple-light);color:var(--fc-purple);padding:2px 7px;border-radius:4px;margin-bottom:4px}.sub-preview{font-size:12px;color:#666;line-height:1.4}.uptime-bars{display:flex;gap:2px;margin-bottom:5px}.seg{height:18px;flex:1 1;border-radius:2px;background:#9fe1cb}.seg.degraded{background:#fac775}.seg.down{background:#f5c4b3}.seg.unknown{background:#e5e5e3}.uptime-meta{display:flex;justify-content:space-between;font-size:10px;color:#aaa}.incident-row{padding:10px 0;border-bottom:.5px solid #e5e5e3}.incident-row:last-child{border-bottom:none}.incident-header{display:flex;justify-content:space-between;margin-bottom:3px}.incident-title{font-size:13px;font-weight:500;color:#111}.incident-meta{font-size:11px;color:#aaa}.incident-note{font-size:12px;color:#666}.loading-state{padding:32px 14px;color:#aaa}.error-state,.loading-state{text-align:center;font-size:13px}.error-state{padding:20px 14px;color:var(--red)}.empty-state{padding:32px 14px;text-align:center;color:#aaa;font-size:13px}