@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap";:root{--text:#475569;--text-h:#0f172a;--bg:#f8fafc;--border:#e2e8f0;--code-bg:#eef2f7;--accent:#0ea5e9;--accent-bg:#0ea5e91f;--accent-border:#0ea5e973;--social-bg:#f1f5f9b3;--shadow:#0f172a26 0 20px 30px -18px, #0f172a14 0 8px 12px -10px;--sans:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;--heading:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, Consolas, monospace;font:17px/150% var(--sans);letter-spacing:.2px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (width<=1024px){:root{font-size:16px}}#root{text-align:center;box-sizing:border-box;background:0 0;border-inline:none;flex-direction:column;width:1200px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{background:linear-gradient(160deg,#f8fafc 0%,#eef2ff 55%,#f8fafc 100%);margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:600}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.dashboard{flex-direction:column;gap:24px;padding:32px 24px 56px;display:flex}.header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.title{margin:0;font-size:24px;font-weight:700}.subtitle{color:#6b7280;margin:4px 0 0;font-size:14px}.header-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.btn{color:#f8fafc;cursor:pointer;background:#0f172a;border:1px solid #0f172a;border-radius:8px;justify-content:center;align-items:center;padding:8px 14px;font-size:14px;text-decoration:none;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 6px 16px #0f172a2e}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px #0f172a33}.btn-outline{color:#0f172a;box-shadow:none;background:#fff;border-color:#e2e8f0}.btn-icon{width:40px;height:40px;padding:0}.source-toggle{border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;display:inline-flex}.label{color:#374151;font-size:12px}.status-dot{background:#9ca3af;border-radius:50%;width:10px;height:10px}.status-dot.ok{background:#16a34a}.status-banner{background:linear-gradient(135deg,#fff 0%,#f1f5f9 100%);border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:16px;padding:16px;display:flex}.status-banner.warning{background:linear-gradient(135deg,#fff7ed 0%,#fffbeb 100%);border-color:#f59e0b}.status-banner.critical{background:linear-gradient(135deg,#fff1f2 0%,#fef2f2 100%);border-color:#ef4444}.status-icon{color:#f9fafb;background:#111827;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-weight:700;display:flex}.status-text{flex:1}.status-title{margin-bottom:4px;font-weight:600}.status-sub{color:#6b7280;font-size:12px}.sensor-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.machine-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;display:grid}.machine-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:12px;gap:12px;padding:14px;display:grid}.machine-card.active{border-color:#111827;box-shadow:0 0 0 1px #111827}.machine-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.machine-label{font-weight:600}.machine-id{color:#6b7280;font-size:11px}.status-pill{color:#111827;background:#e5e7eb;border-radius:999px;padding:3px 8px;font-size:10px}.status-pill.ok{color:#15803d;background:#dcfce7}.status-pill.warning{color:#b45309;background:#fef3c7}.status-pill.critical{color:#b91c1c;background:#fee2e2}.machine-metrics{gap:6px;display:grid}.metric{color:#374151;justify-content:space-between;font-size:12px;display:flex}.metric-label{color:#6b7280}.monitor-panel{text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:16px;gap:16px;padding:20px;display:grid;box-shadow:0 16px 30px #0f172a14}.monitor-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.monitor-header h3{margin:0 0 4px}.monitor-header p{color:#64748b;margin:0;font-size:13px}.monitor-body{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:16px;display:grid}.monitor-frame{box-sizing:border-box;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;justify-content:center;align-items:center;height:100%;min-height:260px;padding:16px;display:flex;position:relative;overflow:hidden}.monitor-frame img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.monitor-overlay{color:#f8fafc;background:#0f172a59;justify-content:center;align-items:center;font-weight:600;display:flex;position:absolute;inset:0}.monitor-details{gap:16px;display:grid}.monitor-meta{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;gap:8px;padding:12px;display:grid}.meta-row{justify-content:space-between;font-size:13px;display:flex}.meta-label{color:#64748b}.meta-value{color:#0f172a;font-weight:600}.monitor-results{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px}.monitor-results h4{margin:0 0 8px;font-size:14px}.monitor-results ul{gap:6px;margin:0;padding:0;list-style:none;display:grid}.monitor-results li{color:#475569;justify-content:space-between;font-size:12px;display:flex}.chip{color:#0369a1;background:#e0f2fe;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.monitor-error{color:#b91c1c;font-size:12px}.monitor-empty{color:#94a3b8;font-size:12px}@media (width<=900px){.monitor-body{grid-template-columns:1fr}}.chart-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;box-shadow:0 12px 24px #0f172a0f}.card-alert{background:#fef2f2;border-color:#ef4444}.card-label{color:#6b7280;margin-bottom:8px;font-size:12px}.card-value{font-size:20px;font-weight:700}.card-unit{color:#6b7280;margin-left:6px;font-size:12px}.badge{color:#b91c1c;background:#fee2e2;border-radius:999px;margin-top:8px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-flex}.chart{width:100%;height:160px}.chart-empty{color:#6b7280;justify-content:center;align-items:center;height:160px;font-size:12px;display:flex}.chart-card .card-label{margin-bottom:10px}.chart-wrap{height:180px}.config-card{color:#374151;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;gap:6px;padding:16px;font-size:13px;display:grid}.config-card code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.hub-container{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:48px 24px;display:flex;position:relative;overflow:hidden}.glow-circle{filter:blur(120px);opacity:.15;z-index:-1;pointer-events:none;border-radius:50%;position:absolute}.glow-circle-1{background:radial-gradient(circle,#0ea5e9 0%,#6366f1 100%);width:400px;height:400px;top:-10%;left:10%}.glow-circle-2{background:radial-gradient(circle,#f59e0b 0%,#ec4899 100%);width:450px;height:450px;bottom:-10%;right:10%}.hub-header{text-align:center;z-index:1;max-width:680px;margin-bottom:48px}.hub-badge{letter-spacing:1.5px;text-transform:uppercase;color:#0ea5e9;background:#0ea5e914;border:1px solid #0ea5e933;border-radius:999px;margin-bottom:16px;padding:4px 12px;font-size:11px;font-weight:700;animation:3s infinite alternate pulse;display:inline-block}.hub-title{letter-spacing:-1.5px;color:#0f172a;margin:0 0 16px;font-size:48px;font-weight:800;line-height:1.15}.title-gradient{background:linear-gradient(135deg,#0ea5e9 0%,#6366f1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hub-subtitle{color:#64748b;margin:0;font-size:16px;line-height:1.6}.hub-grid{z-index:1;grid-template-columns:repeat(2,minmax(280px,420px));justify-content:center;gap:28px;width:100%;max-width:900px;margin-bottom:48px;display:grid}.hub-card{text-align:left;-webkit-backdrop-filter:blur(12px);color:inherit;cursor:pointer;background:#ffffffb3;border:1px solid #e2e8f0cc;border-radius:20px;flex-direction:column;align-items:flex-start;padding:32px;text-decoration:none;transition:all .35s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 10px 30px -10px #0f172a0d}.hub-card:hover{background:#fffffff2;border-color:#0ea5e966;transform:translateY(-6px);box-shadow:0 20px 40px -15px #0ea5e91f,0 0 0 1px #0ea5e91a}.hub-card:focus-visible{outline-offset:2px;outline:2px solid #0ea5e9}.hub-card-icon-wrap{color:#fff;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:24px;transition:transform .3s;display:flex}.hub-card:hover .hub-card-icon-wrap{transform:scale(1.08)rotate(3deg)}.bg-blue-grad{background:linear-gradient(135deg,#0ea5e9 0%,#6366f1 100%);box-shadow:0 8px 16px #0ea5e940}.bg-orange-grad{background:linear-gradient(135deg,#f59e0b 0%,#ec4899 100%);box-shadow:0 8px 16px #f59e0b40}.hub-card-icon{width:28px;height:28px}.hub-card-title{color:#0f172a;letter-spacing:-.5px;font-size:22px;font-weight:700;margin:0 0 12px!important}.hub-card-desc{color:#475569;flex-grow:1;margin:0 0 28px;font-size:14px;line-height:1.55}.hub-card-btn{color:#0f172a;border-bottom:2px solid #0000;align-items:center;padding-bottom:2px;font-size:14px;font-weight:600;transition:all .25s;display:inline-flex}.hub-card:hover .hub-card-btn{color:#0ea5e9;border-bottom-color:#0ea5e9;padding-left:4px}.hub-footer{text-align:center;color:#94a3b8;z-index:1;font-size:13px}@media (width<=768px){.hub-title{font-size:36px}.hub-grid{grid-template-columns:1fr;gap:20px;max-width:420px}.hub-container{padding:36px 16px}}@keyframes pulse{0%{box-shadow:0 0 #0ea5e933}to{box-shadow:0 0 0 6px #0ea5e900}}.prov-container{box-sizing:border-box;background:linear-gradient(160deg,#f8fafc 0%,#eef2ff 55%,#f8fafc 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.prov-card{-webkit-backdrop-filter:blur(16px);text-align:center;background:#fffc;border:1px solid #e2e8f0cc;border-radius:24px;width:100%;max-width:500px;padding:48px;box-shadow:0 20px 40px -15px #0f172a14}.prov-spinner-wrap{width:80px;height:80px;margin:0 auto 24px;position:relative}.prov-spinner{border:4px solid #0ea5e91a;border-top-color:#0ea5e9;border-radius:50%;width:80px;height:80px;animation:1s linear infinite spin}.prov-spinner-inner{border:4px solid #0000;border-bottom-color:#6366f1;border-radius:50%;width:60px;height:60px;animation:1.5s linear infinite reverse spin;position:absolute;top:10px;left:10px}.prov-title{background:linear-gradient(135deg,#0ea5e9 0%,#6366f1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0 0 8px;font-size:26px;font-weight:800}.prov-subtitle{color:#64748b;margin:0 0 32px;font-size:14px}.prov-steps{text-align:left;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:12px;padding:20px;display:flex}.prov-step{font-size:13.5px;font-family:var(--sans);align-items:center;gap:12px;transition:all .3s;display:flex}.step-icon{justify-content:center;align-items:center;width:20px;height:20px;font-weight:700;display:flex}.step-pending{color:#94a3b8}.step-active{color:#0ea5e9;font-weight:600;animation:1s infinite alternate pulse-step}.step-done{color:#16a34a;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-step{0%{opacity:.6}to{opacity:1}}.session-banner{-webkit-backdrop-filter:blur(8px);color:#f8fafc;z-index:100;box-sizing:border-box;background:#0f172ae6;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;width:100%;padding:12px 24px;font-size:13.5px;display:flex;position:sticky;top:0}.session-banner.session-warning{background:#dc2626f2}.session-info{align-items:center;gap:10px;display:flex}.session-pulse{background:#10b981;border-radius:50%;width:8px;height:8px;animation:1.5s infinite pulse-green;box-shadow:0 0 #10b98166}.session-banner.session-warning .session-pulse{background:#fff;animation:1s infinite pulse-white}.session-text code{color:#fff;font-family:var(--mono);background:#ffffff26;border-radius:4px;padding:2px 6px;font-size:12px}.session-timer strong{font-family:var(--mono);color:#38bdf8;font-size:14px}.session-banner.session-warning .session-timer strong{color:#fff}@keyframes pulse-green{0%{box-shadow:0 0 #10b981b3}70%{box-shadow:0 0 0 6px #10b98100}to{box-shadow:0 0 #10b98100}}@keyframes pulse-white{0%{box-shadow:0 0 #ffffffb3}70%{box-shadow:0 0 0 6px #fff0}to{box-shadow:0 0 #fff0}}.expire-overlay{-webkit-backdrop-filter:blur(12px);z-index:200;background:#0f172ad9;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.expire-card{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:440px;padding:40px;animation:.4s cubic-bezier(.16,1,.3,1) slide-up;box-shadow:0 25px 50px -12px #00000080}.expire-icon-wrap{color:#ef4444;background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;display:flex}.expire-icon{width:32px;height:32px}.expire-title{color:#0f172a;margin:0 0 12px;font-size:24px;font-weight:700}.expire-desc{color:#475569;margin:0 0 28px;font-size:14.5px;line-height:1.6}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.simulator-page{flex-direction:column;gap:24px;padding:32px 24px 56px;display:flex}.sim-status-banner{color:#475569;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border:1px solid #e2e8f0;border-radius:12px;flex-wrap:wrap;align-items:center;gap:16px;padding:14px 20px;font-size:13px;display:flex}.sim-status-banner code{color:#0f172a;font-family:var(--mono);background:#e2e8f0;border-radius:4px;padding:2px 6px;font-size:12px}.sim-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;display:grid}.sim-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:20px;padding:24px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 10px 25px #0f172a0a}.sim-card:hover{transform:translateY(-2px);box-shadow:0 16px 30px #0f172a14}.sim-card-alert{background:linear-gradient(#fff 0%,#fef2f2 100%);border-color:#ef4444;box-shadow:0 10px 25px #ef44440f}.sim-card-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.sim-card-label{color:#0f172a;font-size:16px;font-weight:700}.sim-card-id{color:#64748b;font-size:11px;font-family:var(--mono)}.sim-fields{flex-direction:column;gap:14px;display:flex}.sim-field{flex-direction:column;gap:6px;display:flex}.sim-field-label{color:#475569;justify-content:space-between;font-size:12px;display:flex}.sim-field-value{color:#0f172a;font-weight:600}.sim-field input[type=range]{accent-color:#0ea5e9;cursor:pointer;background:#e2e8f0;border-radius:3px;width:100%;height:6px}.fault-injection-section{border-top:1px dashed #e2e8f0;flex-direction:column;gap:10px;padding-top:16px;display:flex}.sim-card-alert .fault-injection-section{border-top-color:#fee2e2}.fault-title-mini{letter-spacing:.5px;text-transform:uppercase;color:#64748b;font-size:11px;font-weight:600}.fault-btn-group{flex-wrap:wrap;gap:6px;display:flex}.fault-pill-btn{color:#475569;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500;transition:all .15s}.fault-pill-btn:hover{color:#0f172a;background:#f1f5f9;border-color:#cbd5e1}.fault-pill-btn.active-none{color:#15803d;background:#dcfce7;border-color:#bbf7d0}.fault-pill-btn.active-fault{color:#b91c1c;background:#fee2e2;border-color:#fecaca;animation:2s infinite alternate pulse-border-red}@keyframes pulse-border-red{0%{border-color:#fecaca;box-shadow:0 0 #ef44441a}to{border-color:#fca5a5;box-shadow:0 0 0 4px #ef444426}}.sim-card-topic{color:#94a3b8;font-size:10.5px;font-family:var(--mono);word-break:break-all}.sim-console-controls{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:16px;padding:24px;display:flex;box-shadow:0 12px 30px #0f172a0d}.console-settings-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.interval-control-group{align-items:center;gap:8px;display:flex}.interval-input{color:#0f172a;text-align:center;border:1px solid #cbd5e1;border-radius:6px;width:76px;padding:6px 10px;font-size:13px}.console-button-group{flex-wrap:wrap;gap:8px;display:flex}.btn-start-pub{color:#fff!important;background:#16a34a!important;border-color:#16a34a!important}.btn-start-pub:hover{background:#15803d!important}.btn-stop-pub{color:#fff!important;background:#dc2626!important;border-color:#dc2626!important}.btn-stop-pub:hover{background:#b91c1c!important}.sim-log-viewer{cursor:text;text-align:left;background:#0f172a;border:1px solid #1e293b;border-radius:12px;flex-direction:column;justify-content:space-between;height:320px;padding:16px;display:flex}.log-lines-container{font-family:var(--mono);color:#94a3b8;flex-grow:1;margin-bottom:12px;font-size:12px;line-height:1.6;overflow-y:auto}.sim-cli-form{font-family:var(--mono);border-top:1px solid #1e293b;align-items:start;gap:8px;padding-top:10px;font-size:12px;display:flex}.cli-prompt{color:#38bdf8;font-weight:700}.sim-cli-input{color:#fff;font-family:var(--mono);text-align:left;background:0 0;border:none;outline:none;flex-grow:1;font-size:12px}.log-empty-msg{color:#475569;text-align:left;padding:4px 0;font-style:italic}.log-line{margin-bottom:4px}.log-line.ok{color:#4ade80}.log-line.fault{color:#f87171}.log-line.info{color:#38bdf8}.log-line.warn{color:#fbbf24}.log-time{color:#475569}
