diff --git a/frontend/src/views/landing/LandingView.vue b/frontend/src/views/landing/LandingView.vue
index eef5eb6d..9fb8e46b 100644
--- a/frontend/src/views/landing/LandingView.vue
+++ b/frontend/src/views/landing/LandingView.vue
@@ -181,6 +181,33 @@ requires_openai_auth = true
+
+
+
@@ -381,4 +408,88 @@ requires_openai_auth = true
}
.chart-title { font-size: 12px; color: var(--text-2); margin-bottom: 12px; }
.chart-svg { width: 100%; height: 120px; display: block; }
+
+/* Nav sticky + responsive tweaks (augments puro.css defaults) */
+.nav {
+ position: sticky;
+ top: 0;
+ z-index: 10;
+ background: rgba(10,14,26,0.75);
+ backdrop-filter: blur(12px);
+ border-bottom: 1px solid var(--border);
+}
+.nav-inner {
+ display: flex;
+ align-items: center;
+ gap: 28px;
+ padding: 16px 24px;
+ max-width: 1120px;
+ margin: 0 auto;
+}
+.brand {
+ display: flex;
+ align-items: center;
+ gap: 8px;
+ font-weight: 700;
+ font-size: 16px;
+}
+.brand .hex {
+ color: var(--cyan);
+ font-size: 20px;
+}
+.nav-links {
+ display: flex;
+ gap: 20px;
+ font-size: 14px;
+ color: var(--text-2);
+}
+.nav-links a:hover { color: var(--text-0); }
+.nav-cta {
+ display: flex;
+ gap: 10px;
+ margin-left: auto;
+}
+@media (max-width: 640px) {
+ .nav-links { display: none; }
+}
+
+/* Footer */
+.puro-footer {
+ margin-top: 80px;
+ padding: 60px 24px 40px;
+ border-top: 1px solid var(--border);
+}
+.footer-grid {
+ display: grid;
+ grid-template-columns: 2fr 1fr 1fr 1fr;
+ gap: 36px;
+}
+@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
+.footer-brand .brand { margin-bottom: 12px; }
+.footer-tagline { color: var(--text-2); font-size: 13px; margin-bottom: 8px; }
+.footer-meta { color: var(--text-3); font-size: 12px; line-height: 1.7; }
+.footer-col-title {
+ color: var(--text-0);
+ font-size: 13px;
+ font-weight: 600;
+ margin-bottom: 12px;
+}
+.footer-col a {
+ display: block;
+ color: var(--text-2);
+ font-size: 13px;
+ padding: 4px 0;
+}
+.footer-col a:hover { color: var(--cyan); }
+
+/* pill */
+.pill {
+ display: inline-block;
+ padding: 6px 14px;
+ border: 1px solid var(--border-2);
+ border-radius: 999px;
+ font-size: 12px;
+ color: var(--text-2);
+ background: rgba(15,23,42,0.6);
+}