.portal-container{min-height:80vh;color:#1e293b}.portal-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 1px 3px #0000000a;transition:border-color .2s,box-shadow .2s}.portal-card:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #0000000f}.portal-metric{padding:20px 24px;display:flex;flex-direction:column;gap:8px}.portal-metric .metric-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.portal-metric .metric-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.portal-metric .metric-value{font-size:2rem;font-weight:700;color:#1e293b;line-height:1}.portal-metric .metric-sub{font-size:13px;color:#94a3b8}.portal-metric.placeholder{border-style:dashed;border-color:#e2e8f0;background:#f8fafc}.portal-metric.placeholder .metric-value{font-size:14px;color:#94a3b8;font-weight:400}.metrics-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:16px}.metrics-dashboard-grid>*{min-width:0;overflow:hidden}.robot-pill{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:4px 0;border-radius:6px;font-size:11px;font-weight:600;color:#94a3b8;background:#f8fafc;border:1px solid #e2e8f0;letter-spacing:.02em}.robot-pill.running{color:#059669;background:#ecfdf5;border-color:#a7f3d0}.robot-pill.available{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.robot-pill.down{color:#dc2626;background:#fef2f2;border-color:#fecaca}.robot-pill-dot{width:7px;height:7px;border-radius:50%;background:#cbd5e1;flex-shrink:0}.robot-pill.running .robot-pill-dot{background:#10b981}.robot-pill.available .robot-pill-dot{background:#3b82f6}.robot-pill.down .robot-pill-dot{background:#ef4444}.robot-pill-dot.pulse{animation:pill-pulse 2s ease-in-out infinite}@keyframes pill-pulse{0%,to{opacity:1;box-shadow:0 0 #10b98199}50%{opacity:.3;box-shadow:0 0 6px 5px #10b98100}}.robot-carousel{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:24px}.robot-card{padding:14px;display:flex;flex-direction:column;gap:10px}.robot-card.running{border-color:#a7f3d0;box-shadow:0 0 16px -6px #10b98133}.robot-card.available{border-color:#bfdbfe;box-shadow:0 0 16px -6px #2563eb26}.robot-card.down{opacity:.55;background:#f8fafc}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.online{background:#10b981;box-shadow:0 0 8px #10b98180;animation:pulse-green 2s infinite}.status-dot.offline{background:#ef4444;box-shadow:0 0 6px #ef44444d}.status-dot.unknown{background:#9ca3af}@keyframes pulse-green{0%,to{box-shadow:0 0 #10b98180}70%{box-shadow:0 0 0 8px #10b98100}}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:500}.status-badge.ok{background:#ecfdf5;color:#059669}.status-badge.fail{background:#fef2f2;color:#dc2626}.status-badge.warn{background:#fffbeb;color:#d97706}.status-badge.neutral{background:#f1f5f9;color:#64748b}.portal-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.portal-section-header h3{font-size:16px;font-weight:600;color:#1e293b;margin:0}.portal-tabs{display:flex;gap:4px;margin-bottom:32px;background:#f1f5f9;border-radius:12px;padding:4px;width:-moz-fit-content;width:fit-content}.portal-tab{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;border:none;background:none;transition:all .2s}.portal-tab:hover{color:#334155}.portal-tab.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #00000014}.temp-cool{color:#059669}.temp-warm{color:#d97706}.temp-hot{color:#dc2626}.last-updated{font-size:12px;color:#94a3b8;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.portal-container .ant-table-thead>tr>th{font-size:12px;text-transform:uppercase;letter-spacing:.04em}.portal-container .ant-tag{border:none}.live-feed-list{max-height:280px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.live-feed-row{display:flex;align-items:baseline;gap:10px;padding:4px 0;border-bottom:1px solid #f1f5f9;font-size:12px;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.live-feed-row:last-child{border-bottom:none}.live-feed-row .feed-time{color:#94a3b8;font-size:11px;font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.live-feed-row.new-event{animation:feedHighlight 2s ease-out}@keyframes feedHighlight{0%{background:#3b82f614}to{background:transparent}}.live-rate-badge{display:flex;align-items:center;gap:6px;font-size:14px;color:#10b981;font-weight:600}.live-rate-badge.idle{color:#94a3b8;font-weight:400}@media(max-width:1199px){.metrics-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:767px){.metrics-grid,.robot-carousel{grid-template-columns:repeat(2,1fr)}}
