:root{--bg: #f2f4f7;--bg-elevated: #ffffff;--bot-nav-bg: #111726;--panel: #ffffff;--text: #1f2933;--muted: #6b7280;--border: rgba(31,41,51,.12);--bottom-nav-height: 60px;--header-height: 44px;--text-primary: #1f2933;--text-secondary: var(--muted);--radius-large: 18px;--radius-medium: 12px;--feed-dot-size: 16px;--feed-dot-inner-size: 10px;--feed-green: #21a65b;--feed-red: #f70404;--feed-blue: #1d4ed8;--feed-yellow: #e67812}html[data-theme=dark]{--bg: #0b1020;--bg-elevated: #1a2332;--bot-nav-bg: #111726;--panel: #1a2332;--text: #e5e9f5;--muted: #9ca3c7;--border: rgba(255,255,255,.08);--text-primary: var(--text);--text-secondary: var(--muted)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}.muted{color:var(--text-secondary)}button{background:transparent;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer}.app{min-height:100vh;display:grid;grid-template-rows:auto 1fr var(--bottom-nav-height)}.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:env(safe-area-inset-top) 12px 0 12px;min-height:calc(var(--header-height) + env(safe-area-inset-top));background:var(--bg)}.header-left{display:flex;align-items:center;gap:8px}.subview-title{flex:1;text-align:center;font-weight:700;font-size:16px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header.is-subview .header-actions{justify-content:flex-end}.logo-img{height:36px;display:block}.logo-dark{display:none}.logo-text{font-weight:700}.header-actions{display:flex;align-items:center;gap:8px}.tabs{display:none;border-radius:24px;overflow:hidden;border:1px solid var(--border);background:#ffffff08}.tab{display:inline-flex;align-items:center;padding:8px 14px;font-size:14px;color:var(--muted)}.tab.active,.tab.is-active{background:#ffffff1f;color:var(--text);font-weight:600}.app-main{overflow-y:auto;padding:6px}.more-header{padding:6px 2px 14px}.more-title{font-weight:800;font-size:18px;color:var(--text-primary)}.more-subtitle{margin-top:2px;font-size:13px}.section-title{margin:0 0 8px 8px;font-size:16px;font-weight:600}.top-spacing{margin-top:20px}.section-header{margin:16px 0 8px;font-size:14px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}.toolbar-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.icon-button{border:none;border-radius:999px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft);cursor:pointer}.segmented-control{display:inline-flex;padding:3px;background:#e5e7eb;border-radius:999px}.segmented-control.wide{display:flex;margin:16px 0 8px}.segmented-control.small{margin-top:4px}.segment{border:none;background:transparent;padding:6px 14px;border-radius:999px;font-size:13px;cursor:pointer;color:var(--text-secondary)}.segment.is-selected{background:var(--panel);color:var(--text-primary);box-shadow:0 1px 4px #0f172a29}html[data-theme=dark] .segmented-control{background:#ffffff1a}.bottom-nav{position:sticky;bottom:0;z-index:20;display:flex;align-items:center;justify-content:space-around;background:var(--bot-nav-bg);border-top:1px solid var(--border);color:var(--muted)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 0 4px;font-size:11px;color:inherit}.bottom-nav-item.is-active{color:var(--text)}.bottom-nav-icon{display:flex;align-items:center;justify-content:center}.nav-icon,.header-icon{width:24px;height:24px;display:block;filter:none}html:not([data-theme=dark]) .nav-icon,html:not([data-theme=dark]) .header-icon{filter:invert(1)}.icon-light{display:none}.icon-dark,html[data-theme=dark] .icon-light{display:inline-block}html[data-theme=dark] .icon-dark{display:none}.card-row{width:100%;padding:12px 16px;background:transparent;border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:space-between;font:inherit;cursor:pointer;color:var(--text)}.card-row-icon-text{display:inline-flex;align-items:center;gap:10px}.list{margin:16px 0 0;padding:0;list-style:none;background:var(--panel);border-radius:var(--radius-large);border:1px solid var(--border)}.list--flush{margin-top:0}.list-item{display:flex;width:100%;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.list-item--clickable{cursor:pointer}.list-item--summary{justify-content:space-between}.list-text{flex:1}.menu-item-text{display:flex;align-items:center;gap:10px}.menu-item-icon,.menu-item-icon-spacer{width:20px;height:20px;flex:0 0 20px}.menu-item-icon{display:block;object-fit:contain}html:not([data-theme=dark]) .menu-item-icon{filter:invert(1)}.primary-text{font-weight:600;color:var(--text-primary)}.secondary-text{font-size:13px;color:var(--text-secondary)}.avatar{width:40px;height:40px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;margin-right:12px;flex-shrink:0}.avatar--orange{background:#f97316}.avatar--blue{background:#2563eb}.avatar--large{width:56px;height:56px;font-size:16px}.chevron{margin-left:12px;color:var(--text-secondary);font-size:16px}.sheet-header{display:flex;gap:12px;align-items:center;margin:12px 0}.sheet-title-block{display:flex;flex-direction:column;gap:2px}.sheet-title-avatar{font-weight:700;font-size:16px;color:var(--text-primary)}.details-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.feed-meta-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;color:var(--text-secondary)}.detail-value{font-weight:600;color:var(--text-primary)}.history-title{margin:16px 0 8px;font-size:13px;color:var(--text-secondary)}a{color:#93c5fd;text-decoration:none}a:hover{text-decoration:underline}.card{border-radius:16px;border:1px solid var(--border);padding:12px 8px;margin-bottom:10px;background:var(--panel)}.card-header{display:flex;justify-content:space-between;align-items:center}.card-header-status{display:flex;align-items:center;gap:.5rem}.card-list-title{display:inline-flex;padding:4px 16px;font-weight:600;color:var(--text);font-size:14px}.status-badge{min-width:80px;text-align:center;padding:6px 16px;border-radius:999px;color:#fff;font-weight:600;font-size:13px;background:#9ca3c7}.status-badge-new{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid transparent;white-space:nowrap}.status-badge--green{background:#21a65b}.status-badge--orange{background:#e67812}.status-badge--red{background:#f70404}.status-badge--neutral{background:#6b7280}.status-badge.status-offline{background:#2d2e33}.status-badge.status-off{background:#9ca3c7}.status-badge.status-idle{background:#21a65b}.status-badge.status-warning{background:#e67812}.status-badge.status-alert{background:#f70404}.feeder-offline-msg{font-size:14px;color:var(--muted);font-style:italic;padding:12px 0;text-align:center;width:100%;background:#00000008;border-radius:8px}.feeder-body{display:flex;justify-content:space-between;gap:32px;margin-top:8px}.feeder-details{font-size:13px;color:var(--text)}.feeder-details-row{display:flex;align-items:center;gap:8px;margin:4px 0}.feed-dot-wrapper{width:var(--feed-dot-size);height:var(--feed-dot-size);border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center;background:transparent}.feed-dot-wrapper:after{content:"";width:var(--feed-dot-inner-size);height:var(--feed-dot-inner-size);border-radius:50%;background-color:var(--dot-color, #ccc);position:absolute;z-index:2;border:1px solid var(--bg)}.indicator-dot{width:8px;height:8px;border-radius:50%;background:var(--indicator-color, var(--text));flex-shrink:0}.list-group{display:flex;flex-direction:column;gap:1px}.list-group-card{border-radius:0;margin-bottom:0;border:none;background:var(--panel);padding:12px 8px}.list-group-card:first-child{border-top-left-radius:var(--radius-large);border-top-right-radius:var(--radius-large)}.list-group-card:last-child{border-bottom-left-radius:var(--radius-large);border-bottom-right-radius:var(--radius-large)}.feeder-list-group{gap:var(--card-list-gap)}.feeder-list-group{gap:3px}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.list-group-table{border-collapse:separate;border-spacing:0 3px;width:100%;font-size:13px}.list-group-table thead tr{background:transparent}.list-group-table th,.list-group-table td{padding:8px 12px;text-align:left}.list-group-table th{color:var(--text-secondary)}.list-group-table tr{background:var(--panel)}.feeds-cell{display:flex;gap:6px;align-items:center}.star-cell{width:36px;text-align:right}.star-icon{width:24px;height:24px;display:inline-block}html:not([data-theme=dark]) .star-icon{filter:invert(1)}.list-group-table tbody tr[data-nav-view]{cursor:pointer;height:50px}.list-group-table tbody tr:first-child td:nth-child(4){border-top-left-radius:var(--radius-large)}.list-group-table tbody tr:first-child td:last-child{border-top-right-radius:var(--radius-large)}.list-group-table tbody tr:last-child td:nth-child(4){border-bottom-left-radius:var(--radius-large)}.list-group-table tbody tr:last-child td:last-child{border-bottom-right-radius:var(--radius-large)}#calf-table th:nth-child(1),#calf-table td:nth-child(1),#calf-table th:nth-child(2),#calf-table td:nth-child(2),#calf-table th:nth-child(3),#calf-table td:nth-child(3),#calf-table th:nth-child(5),#calf-table td:nth-child(5){display:none}#calf-table th:nth-child(4),#calf-table td:nth-child(4){min-width:80px}.feeder-link{color:inherit;text-decoration:none;cursor:pointer}.page{min-height:100vh;display:flex;flex-direction:column}.topbar{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:baseline;justify-content:space-between;gap:12px}.topbar h1{margin:0;font-size:18px}.content{padding:16px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.cards .card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:12px}.card h2{margin:0 0 10px;font-size:16px}.row{display:grid;grid-template-columns:110px 1fr;gap:8px;padding:6px 0;border-top:1px solid var(--border)}.row:first-of-type{border-top:0}.label{color:var(--muted)}.dots{display:flex;gap:8px;align-items:center}.dot{width:10px;height:10px;border-radius:999px;border:1px solid var(--border)}.dot[data-on="1"][data-color=blue]{background:#3b82f6}.dot[data-on="1"][data-color=amber]{background:#f59e0b}.dot[data-on="1"][data-color=green]{background:#22c55e}.dropdown-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:40}.dropdown-menu{position:fixed;top:calc(var(--header-height) + env(safe-area-inset-top) + 8px);right:12px;width:min(75vw,520px);z-index:50}.dropdown-menu-items{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-medium);overflow:hidden;box-shadow:0 16px 40px #00000040}.dropdown-menu-item{width:100%;padding:12px 14px;text-align:left;font-size:14px;color:var(--text)}.dropdown-menu-item+.dropdown-menu-item{border-top:1px solid var(--border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:60}.modal-root{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:70;padding:16px}.modal-card{width:min(520px,100%);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-medium);box-shadow:0 20px 60px #00000059;padding:14px}.modal-title{font-weight:700;font-size:16px;margin-bottom:10px}.modal-body{display:flex;flex-direction:column;gap:10px}.modal-body label{font-size:13px;font-weight:700;color:var(--text-secondary)}.modal-body input,.modal-body select{padding:10px 12px;font-size:15px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text)}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.modal-btn{padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elevated);font-weight:600}.modal-btn--save{background:#21a65b26;border-color:#21a65b59}.modal-btn--cancel{background:#6b72801a}@media (min-width: 900px){.tabs{display:inline-flex}.bottom-nav{display:none}.app{grid-template-rows:auto 1fr;max-width:1000px;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border)}#calf-table th:nth-child(1),#calf-table td:nth-child(1),#calf-table th:nth-child(2),#calf-table td:nth-child(2),#calf-table th:nth-child(3),#calf-table td:nth-child(3),#calf-table th:nth-child(5),#calf-table td:nth-child(5){display:table-cell}}.hidden{display:none}
