:root{color:#e5edf7;background:#0a0f17;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#101d2df0,#0a0f17),#0a0f17}button,input,a{font:inherit}.shell{width:min(1440px,calc(100vw - 32px));margin:0 auto;padding:28px 0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:22px}.topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}h1,h2,p{margin:0}h1{font-size:22px;font-weight:700}.topbar p,.instance p{margin-top:5px;color:#91a2b8;font-size:14px}.layout{display:grid;grid-template-columns:minmax(300px,340px) minmax(0,1fr);gap:18px;align-items:start}.panel{border:1px solid #223047;border-radius:8px;background:#101824;padding:18px;box-shadow:0 18px 40px #0003}.panel-title{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:#c9d8ea;font-size:14px;font-weight:700}.panel-title-row{justify-content:space-between}.panel-title-row span{display:inline-flex;align-items:center;gap:8px}.panel-title-row strong{color:#91a2b8;font-size:12px}label{display:block;margin-bottom:14px}label span{display:block;margin-bottom:7px;color:#9bacbf;font-size:13px}input{width:100%;height:42px;border:1px solid #2a3a53;border-radius:6px;background:#0b111b;color:#e5edf7;padding:0 12px;outline:none}input:focus{border-color:#22d3ee;box-shadow:0 0 0 3px #22d3ee1f}button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:0;border-radius:6px;padding:0 14px;color:#07101a;font-weight:700;cursor:pointer}a{text-decoration:none}button:disabled{cursor:not-allowed;opacity:.45}.primary{width:100%;background:#22d3ee}.start{background:#22d3ee}.compact{width:auto;white-space:nowrap}.stop{background:#fb7185;color:#18050a}.danger{background:#f43f5e;color:#18050a}.secondary{background:#25354c;color:#dbe7f5}.link-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:6px;padding:0 14px;font-weight:700}.state{border:1px solid #344156;border-radius:999px;background:#1c2635;color:#d1d8e4;padding:8px 12px;font-size:12px;font-weight:800;letter-spacing:.04em;white-space:nowrap}.state-running{border-color:#34d39959;background:#34d3991f;color:#86efac}.state-stopped{border-color:#fbbf2459;background:#fbbf241f;color:#fde68a}.state-pending{border-color:#22d3ee59;background:#22d3ee1f;color:#67e8f9}.summary-state{display:flex;align-items:baseline;gap:8px;border:1px solid #344156;border-radius:999px;background:#1c2635;color:#d1d8e4;padding:8px 13px;white-space:nowrap}.summary-state strong{color:#67e8f9;font-size:18px}.summary-state span{color:#aab8ca;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.cost-calculator{margin-bottom:18px}.cost-grid{display:grid;grid-template-columns:repeat(2,minmax(160px,1fr)) minmax(260px,1fr) minmax(220px,.8fr);gap:14px;align-items:end}.cost-grid label{margin:0}.checkbox-row{display:flex;align-items:center;gap:10px;min-height:42px;border:1px solid #2a3a53;border-radius:6px;background:#0b111b;padding:0 12px}.checkbox-row input{width:16px;height:16px;flex:0 0 auto}.checkbox-row span{margin:0;color:#c9d8ea;line-height:1.3}.cost-total{border:1px solid rgba(34,211,238,.28);border-radius:8px;background:#22d3ee14;padding:12px 14px}.cost-total span,.cost-breakdown span,.cost-note{color:#91a2b8;font-size:12px}.cost-total strong{display:block;margin-top:4px;color:#67e8f9;font-size:24px}.cost-breakdown{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-top:14px}.cost-breakdown div{min-width:0;border:1px solid #223047;border-radius:8px;background:#0b111b;padding:10px 12px}.cost-breakdown strong{display:block;margin-top:5px;color:#dbe7f5;font-size:15px}.cost-note{margin-top:12px;line-height:1.5}.node-list{display:grid;gap:14px}.node-card{border:1px solid #223047;border-radius:8px;background:#0c131d;padding:14px}.node-card-running{border-color:#34d39966;box-shadow:0 0 0 1px #34d39914}.instance{display:flex;gap:16px;align-items:flex-start;min-height:104px;padding:2px}.create-node{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,auto) auto;gap:10px;margin-bottom:14px}.image-type-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));min-height:42px;border:1px solid #2a3a53;border-radius:6px;background:#0b111b;overflow:hidden}.image-type-picker button{min-height:40px;border-radius:0;background:transparent;color:#aab8ca}.image-type-picker button.selected{background:#22d3ee;color:#07101a}.instance svg{color:#22d3ee;flex:0 0 auto}.instance h2{font-size:18px}.node-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.node-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.image-type-badge{border:1px solid rgba(167,139,250,.35);border-radius:999px;background:#a78bfa1f;color:#ddd6fe;padding:8px 12px;font-size:12px;font-weight:800;letter-spacing:.04em;white-space:nowrap}.node-runtime{margin-top:12px;color:#dbeafe;font-size:14px;font-weight:700}.app-status{display:inline-flex;margin-top:8px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:800;letter-spacing:.04em}.app-ready{border:1px solid rgba(52,211,153,.35);background:#34d3991f;color:#86efac}.app-booting{border:1px solid rgba(251,191,36,.35);background:#fbbf241f;color:#fde68a}.ip-link{display:inline-flex;align-items:center;gap:7px;max-width:min(100%,560px);margin-top:10px;border:1px solid #27384f;border-radius:6px;background:#070c13;color:#a7f3d0;padding:6px 8px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;overflow-wrap:anywhere}.ip-link:hover{border-color:#22d3eea6;color:#cffafe}.node-addresses{display:grid;justify-items:start;gap:4px}.ip-note{color:#8492a6;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.icon-button{width:42px;padding:0}.facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:14px 0 0}.traffic-facts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0 0}.facts div{min-width:0;border-top:1px solid #223047;padding-top:10px}.traffic-facts div{min-width:0;border:1px solid #223047;border-radius:8px;background:#0b111b;padding:10px 12px}dt{color:#7f90a5;font-size:12px}dd{margin:4px 0 0;color:#cbd8e8;font-size:13px;overflow-wrap:anywhere}.error{margin-top:18px;border:1px solid rgba(251,113,133,.35);border-radius:8px;background:#fb71851a;color:#fecdd3;padding:12px 14px;font-size:14px}.node-notice{display:grid;gap:4px;margin-top:14px;border:1px solid rgba(250,204,21,.42);border-radius:8px;background:#facc151a;color:#fde68a;padding:12px 14px}.node-notice strong{color:#fef3c7;font-size:13px}.node-notice span{color:#fef9c3;font-size:13px;line-height:1.45}.empty-state{border:1px dashed #2a3a53;border-radius:8px;color:#91a2b8;padding:22px;text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#03070cbd;padding:20px}.history-modal{width:min(760px,100%);max-height:min(720px,calc(100vh - 40px));overflow:auto;border:1px solid #2a3a53;border-radius:10px;background:#101824;padding:18px;box-shadow:0 24px 70px #0000006b}.modal-title{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.modal-title h2{font-size:18px}.modal-title p{margin-top:4px;color:#91a2b8;font-size:13px}.history-table{width:100%;border-collapse:collapse;overflow:hidden;border:1px solid #223047;border-radius:8px;font-size:13px}.history-table th,.history-table td{border-bottom:1px solid #223047;padding:11px 12px;text-align:left}.history-table th{background:#0b111b;color:#91a2b8;font-size:11px;letter-spacing:.04em;text-transform:uppercase}.history-table td{color:#dbe7f5}.history-table tr:last-child td{border-bottom:0}@media(max-width:820px){.topbar,.layout,.topbar-actions{display:grid;grid-template-columns:1fr}.create-node,.cost-grid,.cost-breakdown{grid-template-columns:1fr}.actions button{flex:1 1 140px}.create-node{grid-template-columns:1fr}.compact{width:100%}.node-heading,.summary-state{align-items:flex-start}.node-heading{display:grid;grid-template-columns:1fr}.facts,.traffic-facts{grid-template-columns:1fr}}
