*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-bg: #0f1117;--c-surface: #1a1d27;--c-surface-2: #21253a;--c-border: #2e3350;--c-text: #e2e4ef;--c-text-muted: #6b7280;--c-text-sub: #9ca3af;--c-primary: #4f8ef7;--c-primary-dk: #3a72d8;--c-danger: #ef4444;--c-danger-dk: #dc2626;--c-success: #22c55e;--c-day: #f5c518;--c-day-bg: rgba(245, 197, 24, .08);--c-night: #818cf8;--c-night-bg: rgba(129, 140, 248, .08);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--font-mono: "SF Mono", "Cascadia Code", "Consolas", monospace;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}html{font-size:16px;overflow-x:hidden;width:100%;-webkit-text-size-adjust:100%}body{font-family:var(--font-ui);background:var(--c-bg);color:var(--c-text);line-height:1.5;min-height:100dvh;overflow-x:hidden;width:100%;position:relative}.muted{color:var(--c-text-muted);font-size:.875rem}.error-msg{color:var(--c-danger);font-size:.875rem;padding:var(--sp-2) 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-1);border:none;border-radius:var(--r-sm);font-family:var(--font-ui);font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 1rem;transition:background .15s,opacity .15s;white-space:nowrap;line-height:1;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--c-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--c-primary-dk)}.btn--secondary{background:var(--c-surface-2);color:var(--c-text);border:1px solid var(--c-border)}.btn--secondary:hover:not(:disabled){background:var(--c-border)}.btn--ghost{background:transparent;color:var(--c-text-sub);border:1px solid var(--c-border)}.btn--ghost:hover:not(:disabled){background:var(--c-surface-2);color:var(--c-text)}.btn--danger{background:var(--c-danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--c-danger-dk)}.btn--ghost.btn--danger{background:transparent;color:var(--c-danger);border-color:var(--c-danger)}.btn--ghost.btn--danger:hover:not(:disabled){background:#ef44441f;color:var(--c-danger-dk);border-color:var(--c-danger-dk)}.btn--success{background:var(--c-success);color:#fff}.btn--sm{padding:.375rem .75rem;font-size:.8125rem}.btn--xs{padding:.25rem .5rem;font-size:.75rem}#root{min-height:100%;width:100%;max-width:100%;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100dvh;width:100%;max-width:100%;overflow-x:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);background:var(--c-surface);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:10}.app-header__logo{font-weight:700;font-size:1rem;letter-spacing:-.01em;flex:1;text-align:center;margin:0 var(--sp-2)}.app-config-bar{background:var(--c-surface-2);border-bottom:1px solid var(--c-border);padding:var(--sp-3) var(--sp-4)}.app-body{display:flex;flex-direction:column;flex:1;min-height:0}.app-body__list{flex-shrink:0;min-width:0}.app-body__detail{flex:1;border-top:1px solid var(--c-border);min-height:0;min-width:0;overflow-x:hidden}@media(max-width:599px){.app-body{height:calc(100dvh - 53px);overflow:hidden}.app-body--detail-active .app-body__list{display:none}.app-body--detail-active .app-body__detail{display:flex;flex-direction:column;flex:1;overflow-x:hidden;overflow-y:auto;min-height:0;border-top:none}.app-body:not(.app-body--detail-active) .app-body__detail{display:none}.app-body:not(.app-body--detail-active) .app-body__list{overflow-x:hidden;overflow-y:auto;flex:1;min-height:0}}.app-header__back{flex-shrink:0}@media(min-width:600px){.app-header__back{display:none}}@media(min-width:600px){.app-body{flex-direction:row;overflow:hidden;height:calc(100dvh - 53px)}.app-body__list{width:300px;border-right:1px solid var(--c-border);overflow-x:hidden;overflow-y:auto;height:100%;flex-shrink:0}.app-body__detail{flex:1;overflow-x:hidden;overflow-y:auto;height:100%;border-top:none}}@media(min-width:900px){.app-body__list{width:360px}}.detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);height:100%;min-height:200px;padding:var(--sp-6);text-align:center}.api-config__label{display:block;font-size:.75rem;color:var(--c-text-muted);margin-bottom:var(--sp-1);text-transform:uppercase;letter-spacing:.06em}.api-config__row{display:flex;gap:var(--sp-2);align-items:center}.api-config__input{flex:1;background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);padding:.375rem .625rem;border-radius:var(--r-sm);font-family:var(--font-mono);font-size:.8125rem;min-width:0}.api-config__input:focus{outline:2px solid var(--c-primary);outline-offset:-1px}.server-list{padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3)}.server-list__header{display:flex;align-items:center;justify-content:space-between}.server-list__title{font-size:1rem;font-weight:600}.server-list__search{width:100%;background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);padding:.5rem .75rem;border-radius:var(--r-sm);font-size:.875rem}.server-list__search:focus{outline:2px solid var(--c-primary);outline-offset:-1px}.server-list__items{list-style:none;display:flex;flex-direction:column;gap:var(--sp-2)}.server-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);overflow:hidden;transition:border-color .15s}.server-card:hover{border-color:var(--c-primary)}.server-card--selected{border-color:var(--c-primary);background:color-mix(in srgb,var(--c-primary) 6%,var(--c-surface))}.server-card--auto-polling{border-left:3px solid var(--c-primary)}.server-card__main{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:var(--sp-3) var(--sp-3) var(--sp-2);background:none;border:none;color:var(--c-text);cursor:pointer;text-align:left;font-family:var(--font-ui)}.server-card__main:focus-visible{outline:2px solid var(--c-primary);outline-offset:-2px}.server-card__name{font-weight:600;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:inline-flex;align-items:center;gap:var(--sp-2)}.server-card__auto-badge{flex-shrink:0;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--c-primary);background:color-mix(in srgb,var(--c-primary) 18%,transparent);padding:.15rem .4rem;border-radius:99px}.server-card__meta{font-size:.75rem;color:var(--c-text-muted);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.server-card__polled{font-size:.7rem;color:var(--c-text-muted)}.server-card__actions{display:flex;gap:var(--sp-1);padding:var(--sp-1) var(--sp-2) var(--sp-2);border-top:1px solid var(--c-border)}.server-detail{padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-5);max-width:760px;width:100%;min-width:0}@media(min-width:900px){.server-detail{padding:var(--sp-6)}}.server-detail__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap}.server-detail__name{font-size:1.25rem;font-weight:700}.server-detail__meta{font-size:.8125rem;color:var(--c-text-muted);font-family:var(--font-mono);margin-top:2px}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3)}@media(min-width:480px){.stat-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-1)}.stat-card--day{border-color:var(--c-day);background:var(--c-day-bg)}.stat-card--night{border-color:var(--c-night);background:var(--c-night-bg)}.stat-card__value--mono{font-family:var(--font-mono);font-size:1.4rem;letter-spacing:.03em}.stat-card__label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.07em;color:var(--c-text-muted)}.stat-card__value{font-size:1.25rem;font-weight:700;line-height:1.2}.stat-card__sub{font-size:.6875rem;color:var(--c-text-muted)}.server-detail__section{display:flex;flex-direction:column;gap:var(--sp-3)}.server-detail__section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap}.server-detail__section-title{font-size:.9375rem;font-weight:600}.horizon-control{display:flex;align-items:center;gap:var(--sp-2);font-size:.875rem;color:var(--c-text-sub)}.horizon-input{width:56px;background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);border-radius:var(--r-sm);padding:.25rem .5rem;font-size:.875rem;text-align:center}.horizon-input:focus{outline:2px solid var(--c-primary);outline-offset:-1px}.prediction-list{list-style:none;display:flex;flex-direction:column;gap:var(--sp-2)}.prediction-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-sm);font-size:.9375rem;min-width:0;overflow:hidden}.prediction-item--day{border-left:3px solid var(--c-day)}.prediction-item--night{border-left:3px solid var(--c-night)}.prediction-item__icon{font-size:1.1rem;flex-shrink:0}.prediction-item__state{font-weight:600;width:3.5rem;flex-shrink:0}.prediction-item__time{font-family:var(--font-mono);font-size:.9375rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prediction-item__until{color:var(--c-text-muted);font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.solar-times{display:flex;gap:var(--sp-3);flex-wrap:wrap}.solar-time{display:flex;align-items:center;gap:var(--sp-2);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3);font-size:.875rem;flex:1;min-width:0}@media(min-width:380px){.solar-time{min-width:160px}}.solar-time__icon{font-size:1.1rem;flex-shrink:0}.solar-time__label{color:var(--c-text-muted);font-size:.75rem;width:3.5rem}.solar-time__value{display:flex;align-items:center;gap:var(--sp-2);font-weight:600;font-family:var(--font-mono)}.badge{display:inline-flex;align-items:center;padding:0 6px;border-radius:99px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1.6;font-family:var(--font-ui)}.badge--observed{background:#22c55e26;color:#4ade80}.badge--assumed{background:#9ca3af26;color:#9ca3af}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0}@media(min-width:600px){.modal-overlay{align-items:center;padding:var(--sp-4)}}.modal{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg) var(--r-lg) 0 0;width:100%;max-height:92dvh;overflow-y:auto;display:flex;flex-direction:column;animation:slide-up .2s ease}@media(min-width:600px){.modal{border-radius:var(--r-lg);max-width:480px;width:100%;animation:fade-in .15s ease}}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--c-border);position:sticky;top:0;background:var(--c-surface);z-index:1}.modal__title{font-size:1rem;font-weight:600}.modal__close{background:none;border:none;font-size:1.5rem;color:var(--c-text-muted);cursor:pointer;line-height:1;padding:var(--sp-1)}.modal__close:hover{color:var(--c-text)}.modal__body{padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4);flex:1}.modal__server-id{font-size:.8125rem;color:var(--c-text-muted);font-family:var(--font-mono);background:var(--c-bg);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-sm)}.modal__footer{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--c-border);position:sticky;bottom:0;background:var(--c-surface)}.field{display:flex;flex-direction:column;gap:var(--sp-1)}.field__label{font-size:.8125rem;font-weight:500;color:var(--c-text-sub)}.field__required{color:var(--c-danger);margin-left:2px}.field__input{background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);padding:.5rem .75rem;border-radius:var(--r-sm);font-size:.9375rem;font-family:var(--font-ui);width:100%;transition:border-color .15s}.field__input:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px #4f8ef726}.poll-controls{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;flex-shrink:0}.poll-countdown{font-family:var(--font-mono);font-size:.8125rem;color:var(--c-text-muted);min-width:2.5rem;text-align:right}.poll-interval-row{display:flex;align-items:center;gap:var(--sp-2);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-sm);padding:var(--sp-2) var(--sp-3)}.poll-interval-label{font-size:.8125rem;color:var(--c-text-muted)}.poll-interval-input{width:64px;background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);border-radius:var(--r-sm);padding:.25rem .5rem;font-size:.875rem;text-align:center}.poll-interval-input:focus{outline:2px solid var(--c-primary);outline-offset:-1px}.accel-row{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.accel-chip{display:inline-flex;align-items:center;gap:4px;padding:.25rem .625rem;border-radius:99px;font-size:.8125rem;font-weight:600;font-family:var(--font-mono);border:1px solid transparent}.accel-chip--day{background:var(--c-day-bg);border-color:var(--c-day);color:var(--c-day)}.accel-chip--night{background:var(--c-night-bg);border-color:var(--c-night);color:var(--c-night)}.accel-chip--active{background:var(--c-surface-2);border-color:var(--c-border);color:var(--c-text-sub);font-style:italic}
