:root{font-family:Inter,Segoe UI,Arial,sans-serif;color:#1d2430;background:#f4f6f8}*{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}button{border:1px solid #1d6f42;background:#1d6f42;color:#fff;border-radius:6px;padding:8px 10px;cursor:pointer}button:disabled{cursor:wait;opacity:.65}button.ghost{background:#fff;color:#1d2430;border-color:#c8d0d9}button.danger{border-color:#b42318;color:#fff;background:#b42318}button.danger.ghost{background:#fff;color:#b42318}button.full-width{width:100%}input,select,textarea{width:100%;border:1px solid #c8d0d9;border-radius:6px;padding:8px;background:#fff;color:#1d2430}textarea{min-height:90px;resize:vertical}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid #dce2e8;padding:14px;overflow-y:auto}.sidebar section,.sidebar>div{margin-bottom:14px}.sidebar section{padding-top:12px;border-top:1px solid #e6ebf0}.sidebar section:first-of-type{padding-top:0;border-top:0}.sidebar h2{margin:0 0 8px;font-size:15px}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#b42318;color:#fff;font-size:12px}.sidebar p{margin:6px 0}.sidebar-empty{color:#5b6674;font-size:12px}.alert-sidebar-group{margin-top:10px;display:grid;gap:6px}.alert-sidebar-row{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;font-size:12px}.alert-sidebar-row.unread{font-weight:700}.alert-symbol-button{padding:4px 8px}.inline-form{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:8px}.confirm-box{border:1px solid #ffd2cc;background:#fff4f2;border-radius:6px;padding:8px;margin:8px 0}.confirm-box button{margin-right:6px}.watchlist-delete{margin-top:10px}.column-panel summary{cursor:pointer;font-weight:700;font-size:15px;margin-bottom:8px;background:#eef2f5;border:1px solid #dce2e8;border-radius:6px;padding:8px 10px}.column-list{display:grid;gap:4px;max-height:260px;overflow:auto;margin-bottom:8px}.column-toggle{display:flex;align-items:center;gap:8px;font-size:13px}.column-toggle input{width:auto}.content{padding:18px;overflow:auto}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.topbar-actions{display:flex;gap:8px;align-items:center}.topbar h1{font-size:24px;line-height:1.2;margin:0 0 4px}.topbar p{margin:0;color:#5b6674;font-size:13px}.table-wrap{width:100%;overflow:auto;background:#fff;border:1px solid #dce2e8;border-radius:6px}table{width:max-content;min-width:100%;border-collapse:collapse;font-size:13px}th,td{border-bottom:1px solid #e6ebf0;padding:8px 10px;text-align:left;white-space:nowrap}th{position:sticky;top:0;background:#eef2f5;z-index:1;cursor:pointer;-webkit-user-select:none;user-select:none}tr:hover td:not(.good):not(.bad):not(.strong):not(.watch):not(.mid){background:#f7fafc}td.good{background:#2ecc71;color:#fff}td.bad{background:#e74c3c;color:#fff}td.strong{background:#16803a;color:#fff}td.watch{background:#fff066;color:#1d2430}td.mid{background:#f7b267;color:#1d2430}td.updating{color:#5b6674;font-style:italic}.failed-row td{background:#eee;color:#666;font-style:italic}.sticky-col{position:sticky;left:0;z-index:2;background:#fff;box-shadow:1px 0 #dce2e8}th.sticky-col{z-index:3;background:#eef2f5}td.good.sticky-col,td.bad.sticky-col,td.strong.sticky-col,td.watch.sticky-col,td.mid.sticky-col{box-shadow:1px 0 #dce2e8}.sort-mark{color:#5b6674;font-size:11px}.notice{border:1px solid #b8d8ff;background:#eef6ff;padding:10px;border-radius:6px;margin-bottom:12px}.status-line{min-height:40px;border:1px solid #b8d8ff;background:#eef6ff;padding:10px;border-radius:6px;margin-bottom:12px}.status-line.error{border-color:#f0a19a;background:#fff1ef;color:#9f1f14;font-weight:700}.status-line.info{border-color:#b8d8ff;background:#eef6ff;color:#1d2430}.status-line.idle{border-color:#dce2e8;background:#fff;color:#5b6674}.soft-prompt{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #dce2e8;background:#fff;padding:10px 12px;border-radius:6px;margin-bottom:12px}.soft-prompt p{margin:4px 0 0;color:#5b6674;font-size:13px}.soft-prompt-actions{display:flex;gap:8px;flex-wrap:wrap}.modal-backdrop{position:fixed;inset:0;background:#141c2659;display:grid;place-items:center;padding:16px;z-index:50}.modal-card{width:min(520px,100%);background:#fff;border:1px solid #dce2e8;border-radius:6px;padding:14px}.modal-card form{display:grid;gap:10px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.modal-header h2{margin:0;font-size:18px}.selected-row td:not(.good):not(.bad):not(.strong):not(.watch):not(.mid){background:#e8f2eb}.chart-panel{margin-top:12px;background:#fff;border:1px solid #dce2e8;border-radius:6px;padding:12px}.chart-panel.muted{color:#5b6674}.chart-header{display:flex;justify-content:space-between;gap:12px;color:#5b6674;font-size:13px;margin-bottom:8px}.chart-title{display:flex;flex-direction:column;gap:4px}.chart-header strong{color:#1d2430}.chart-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px;align-items:end}.chart-toolbar select{width:auto;min-width:180px}.chart-toolbar-secondary{margin-top:-2px}.alert-input-group{display:flex;align-items:center;gap:6px}.alert-input-group span{color:#5b6674;font-size:12px}.alert-input-group input{width:120px}.alert-input-group-edit input{width:140px}.spinbox-hint{color:#5b6674;font-size:12px}.chart-alert-status{min-height:22px;margin-top:8px;color:#5b6674;font-size:12px}.history-chart{display:block;width:100%;height:180px;background:#f7fafc;border:1px solid #e6ebf0;border-radius:6px}.history-chart-advanced{width:100%;height:280px;background:#f7fafc;border:1px solid #e6ebf0;border-radius:6px;overflow:hidden}.empty-state,.center-panel,.auth-shell{display:grid;place-items:center;min-height:100vh}.auth-card{width:min(420px,calc(100vw - 32px));background:#fff;border:1px solid #dce2e8;border-radius:8px;padding:20px}.auth-card h1{margin-top:0}.auth-card label{display:block;margin:12px 0}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:14px 0}.segmented button{background:#fff;color:#1d2430;border-color:#c8d0d9}.segmented button.active{background:#1d6f42;border-color:#1d6f42;color:#fff}.primary{width:100%}.auth-link{width:100%;margin-top:8px}code{display:block;margin:6px 0;padding:8px;background:#fff;border:1px solid #dce2e8;border-radius:6px}@media(max-width:840px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid #dce2e8}.soft-prompt{flex-direction:column;align-items:flex-start}}
