Spaces:
Running
Running
| /* embodied-efficiency design system: the "Deploy Console" identity. | |
| This is a robotics deploy tool, so it should read like an instrument panel: | |
| a cool slate canvas, an electric indigo -> cyan signal, monospace telemetry | |
| readouts, and three honest status colors (go / caution / hold). Distinct on | |
| purpose from my warmer projects. Built on Tailwind utilities; this file holds | |
| the few bespoke pieces (washes, panels, status lights, meters) utilities can't | |
| express well. Light + dark, gentle motion, reduced-motion respected. */ | |
| :root { | |
| --ee-signal: 99 102 241; /* indigo-500, primary signal */ | |
| --ee-signal-deep: 79 70 229; /* indigo-600, deep */ | |
| --ee-cyan: 34 211 238; /* cyan-400, accent */ | |
| /* Honest status bands for the safety layer: go / caution / hold. */ | |
| --ee-go: 16 185 129; /* emerald -> passed, action sent */ | |
| --ee-warn: 217 160 60; /* warm amber -> staleness / caution */ | |
| --ee-hold: 244 100 110; /* soft rose -> intervention, held a safe action */ | |
| } | |
| html { scroll-behavior: smooth; } | |
| body { | |
| font-family: "Inter var", Inter, ui-sans-serif, system-ui, -apple-system, | |
| "Segoe UI", Roboto, Helvetica, Arial, sans-serif; | |
| font-feature-settings: "cv02", "cv03", "cv04", "cv11"; | |
| -webkit-font-smoothing: antialiased; | |
| text-rendering: optimizeLegibility; | |
| } | |
| h1, h2, h3 { letter-spacing: -0.012em; } | |
| /* Telemetry numerals: monospace, tabular, so readouts don't jitter as they | |
| update. Every latency / footprint / score number on the page wears this. */ | |
| .ee-mono { | |
| font-family: "JetBrains Mono", "SFMono-Regular", ui-monospace, "SF Mono", | |
| Menlo, Consolas, monospace; | |
| font-variant-numeric: tabular-nums; | |
| letter-spacing: -0.01em; | |
| } | |
| /* Page wash: a cool signal glow from the corners over a faint blueprint grid. | |
| Quiet enough to read over, present enough to feel like a console. */ | |
| .ee-bg { | |
| background-color: rgb(248 250 252); /* slate-50 */ | |
| background-image: | |
| radial-gradient(60rem 60rem at 112% -10%, rgb(var(--ee-cyan) / 0.10), transparent 56%), | |
| radial-gradient(54rem 54rem at -12% -6%, rgb(var(--ee-signal) / 0.10), transparent 52%), | |
| linear-gradient(to right, rgb(15 23 42 / 0.035) 1px, transparent 1px), | |
| linear-gradient(to bottom, rgb(15 23 42 / 0.035) 1px, transparent 1px); | |
| background-size: auto, auto, 2.25rem 2.25rem, 2.25rem 2.25rem; | |
| } | |
| .dark .ee-bg { | |
| background-color: rgb(8 11 20); | |
| background-image: | |
| radial-gradient(60rem 60rem at 112% -10%, rgb(var(--ee-cyan) / 0.14), transparent 56%), | |
| radial-gradient(54rem 54rem at -12% -6%, rgb(var(--ee-signal) / 0.16), transparent 52%), | |
| linear-gradient(to right, rgb(148 163 184 / 0.06) 1px, transparent 1px), | |
| linear-gradient(to bottom, rgb(148 163 184 / 0.06) 1px, transparent 1px); | |
| } | |
| /* Brand text: an electric indigo -> cyan signal. */ | |
| .ee-gradient-text { | |
| background-image: linear-gradient(100deg, rgb(var(--ee-signal-deep)), rgb(var(--ee-cyan))); | |
| -webkit-background-clip: text; | |
| background-clip: text; | |
| color: transparent; | |
| } | |
| /* Card: an instrument panel. Crisp edge, soft depth, subtle blur. */ | |
| .ee-card { | |
| border-radius: 1rem; | |
| border: 1px solid rgb(226 232 240); /* slate-200 */ | |
| background: rgb(255 255 255 / 0.85); | |
| backdrop-filter: blur(7px); | |
| box-shadow: 0 1px 2px rgb(15 23 42 / 0.05), 0 16px 34px -20px rgb(30 41 120 / 0.28); | |
| } | |
| .dark .ee-card { | |
| border-color: rgb(40 51 74 / 0.8); | |
| background: rgb(15 20 33 / 0.62); | |
| box-shadow: 0 1px 2px rgb(0 0 0 / 0.35), 0 16px 38px -20px rgb(0 0 0 / 0.7); | |
| } | |
| /* Quiet grouped panel (readout strips, log). */ | |
| .ee-panel { background: rgb(241 245 249 / 0.7); } | |
| .dark .ee-panel { background: rgb(13 19 33 / 0.55); } | |
| /* Status pill / chip. */ | |
| .ee-chip { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: 0.4rem; | |
| border-radius: 999px; | |
| padding: 0.2rem 0.7rem; | |
| font-size: 0.72rem; | |
| font-weight: 600; | |
| } | |
| /* Status light: a glowing console indicator. Colour says go / caution / hold. */ | |
| .ee-light { | |
| display: inline-block; | |
| width: 0.7rem; | |
| height: 0.7rem; | |
| border-radius: 999px; | |
| position: relative; | |
| } | |
| .ee-light--go { background: rgb(var(--ee-go)); box-shadow: 0 0 0 3px rgb(var(--ee-go) / 0.18), 0 0 14px rgb(var(--ee-go) / 0.6); } | |
| .ee-light--warn { background: rgb(var(--ee-warn)); box-shadow: 0 0 0 3px rgb(var(--ee-warn) / 0.18), 0 0 14px rgb(var(--ee-warn) / 0.6); } | |
| .ee-light--hold { background: rgb(var(--ee-hold)); box-shadow: 0 0 0 3px rgb(var(--ee-hold) / 0.18), 0 0 14px rgb(var(--ee-hold) / 0.6); } | |
| /* Meter: a slim readout bar (used for the Hz gap + budget fill). */ | |
| .ee-meter { | |
| height: 0.5rem; | |
| border-radius: 999px; | |
| background: rgb(226 232 240); | |
| overflow: hidden; | |
| } | |
| .dark .ee-meter { background: rgb(30 41 59); } | |
| .ee-meter > span { | |
| display: block; | |
| height: 100%; | |
| border-radius: 999px; | |
| background: linear-gradient(90deg, rgb(var(--ee-signal)), rgb(var(--ee-cyan))); | |
| transition: width .6s cubic-bezier(.22,.61,.36,1); | |
| } | |
| .ee-meter--go > span { background: linear-gradient(90deg, rgb(var(--ee-go) / 0.85), rgb(var(--ee-go))); } | |
| .ee-meter--warn > span { background: linear-gradient(90deg, rgb(var(--ee-warn) / 0.85), rgb(var(--ee-warn))); } | |
| .ee-meter--hold > span { background: linear-gradient(90deg, rgb(var(--ee-hold) / 0.85), rgb(var(--ee-hold))); } | |
| /* Gentle lift on interactive cards. */ | |
| .ee-lift { transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; } | |
| .ee-lift:hover { transform: translateY(-2px); } | |
| /* Range sliders, styled to the console (the compiler budget knobs). */ | |
| .ee-range { | |
| -webkit-appearance: none; | |
| appearance: none; | |
| width: 100%; | |
| height: 0.4rem; | |
| border-radius: 999px; | |
| background: rgb(226 232 240); | |
| outline: none; | |
| } | |
| .dark .ee-range { background: rgb(30 41 59); } | |
| .ee-range::-webkit-slider-thumb { | |
| -webkit-appearance: none; | |
| appearance: none; | |
| width: 1.05rem; | |
| height: 1.05rem; | |
| border-radius: 999px; | |
| background: rgb(var(--ee-signal)); | |
| border: 2px solid rgb(255 255 255); | |
| box-shadow: 0 1px 3px rgb(30 41 120 / 0.4); | |
| cursor: pointer; | |
| transition: transform .12s ease; | |
| } | |
| .ee-range::-webkit-slider-thumb:hover { transform: scale(1.12); } | |
| .ee-range::-moz-range-thumb { | |
| width: 1.05rem; | |
| height: 1.05rem; | |
| border-radius: 999px; | |
| background: rgb(var(--ee-signal)); | |
| border: 2px solid rgb(255 255 255); | |
| cursor: pointer; | |
| } | |
| .dark .ee-range::-webkit-slider-thumb { border-color: rgb(15 20 33); } | |
| .dark .ee-range::-moz-range-thumb { border-color: rgb(15 20 33); } | |
| /* htmx loading affordance. */ | |
| .htmx-indicator { opacity: 0; transition: opacity .15s ease; } | |
| .htmx-request .htmx-indicator { opacity: 1; } | |
| .htmx-request.htmx-indicator { opacity: 1; } | |
| .htmx-request button[type="submit"] { opacity: .65; pointer-events: none; } | |
| /* Fade-in for swapped / new content. */ | |
| @keyframes ee-fade-in { | |
| from { opacity: 0; transform: translateY(6px); } | |
| to { opacity: 1; transform: translateY(0); } | |
| } | |
| .ee-fade { animation: ee-fade-in .28s cubic-bezier(.22,.61,.36,1) both; } | |
| /* Slow pulse for the "live" dot: a steady heartbeat. */ | |
| @keyframes ee-breathe { | |
| 0%, 100% { opacity: 1; transform: scale(1); } | |
| 50% { opacity: 0.5; transform: scale(0.82); } | |
| } | |
| .ee-breathe { animation: ee-breathe 3s ease-in-out infinite; } | |
| /* Focus ring: signal indigo, clearly visible. */ | |
| .ee-focus:focus-visible { | |
| outline: none; | |
| box-shadow: 0 0 0 3px rgb(var(--ee-signal) / 0.45); | |
| } | |
| /* Pareto plot points: a soft hover grow. */ | |
| .ee-dot { transition: r .12s ease, opacity .12s ease; cursor: pointer; } | |
| .ee-dot:hover { opacity: 1 ; } | |
| @media (prefers-reduced-motion: reduce) { | |
| .ee-fade, .ee-breathe, .ee-meter > span, .ee-lift, .ee-dot { animation: none; transition: none; } | |
| } | |