:root{--flora-sage:#5c7f6a;--flora-sage-muted:#8aa396;--flora-moss:#3d5a4a;--flora-sky:#0ea5e9;--flora-sky-soft:#e0f2fe;--flora-cream:#f7f9f6;--flora-paper:#fdfdfb;--flora-ink:#1c2e28;--flora-ink-muted:#5c6f68;--flora-border:#dfe8e2;--flora-card:#fff;--flora-shadow:0 1px 2px #1c2e280f, 0 8px 24px #1c2e280f;--color-background:var(--flora-paper);--color-background-soft:var(--flora-cream);--color-background-mute:#eef3ef;--color-border:var(--flora-border);--color-border-hover:#c5d4cc;--color-heading:var(--flora-ink);--color-text:var(--flora-ink);--color-text-mute:var(--flora-ink-muted);--color-accent:var(--flora-sky);--color-accent-soft:var(--flora-sky-soft)}@media (prefers-color-scheme:dark){:root{--flora-cream:#141a18;--flora-paper:#0f1412;--flora-card:#1a2220;--flora-border:#2a3532;--flora-ink:#e8f0ec;--flora-ink-muted:#9fb0a8;--flora-shadow:0 1px 2px #00000059, 0 12px 32px #00000073;--color-background:var(--flora-paper);--color-background-soft:var(--flora-cream);--color-background-mute:#1e2825;--color-border:var(--flora-border);--color-border-hover:#3d4d48;--color-heading:var(--flora-ink);--color-text:#c5d4ce;--color-text-mute:var(--flora-ink-muted);--color-accent:#38bdf8;--color-accent-soft:#38bdf81f}}*,:before,:after{box-sizing:border-box;margin:0;font-weight:400}body{min-height:100vh;color:var(--color-text);background:var(--color-background);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:15px;line-height:1.55}#app{width:100%;max-width:none;min-height:100vh;margin:0;padding:0}.layout[data-v-2ff65ce9]{background:var(--color-background-soft);flex-direction:column;min-height:100vh;display:flex}.top[data-v-2ff65ce9]{border-bottom:1px solid var(--color-border);background:var(--color-background);box-shadow:var(--flora-shadow,0 1px 3px #0000000f);justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1.5rem;display:flex}.brand[data-v-2ff65ce9]{letter-spacing:-.02em;color:var(--color-heading);align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;text-decoration:none;display:inline-flex}.brand-mark[data-v-2ff65ce9]{background:linear-gradient(135deg, var(--flora-sage,#5c7f6a) 0%, var(--flora-moss,#3d5a4a) 100%);border-radius:8px;width:1.75rem;height:1.75rem;box-shadow:inset 0 1px #fff3}.nav[data-v-2ff65ce9]{flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.9rem;display:flex}.nav-link[data-v-2ff65ce9]{color:var(--color-text-mute);border-radius:999px;padding:.4rem .85rem;font-weight:500;text-decoration:none;transition:color .15s,background .15s}.nav-link[data-v-2ff65ce9]:hover{color:var(--color-text);background:var(--color-background-mute)}.nav-link.router-link-active[data-v-2ff65ce9]{color:var(--color-accent);background:var(--color-accent-soft)}.user[data-v-2ff65ce9]{color:var(--color-text-mute);padding:0 .35rem;font-size:.85rem}.logout[data-v-2ff65ce9]{border:1px solid var(--color-border);background:var(--color-background);font:inherit;color:var(--color-text-mute);cursor:pointer;border-radius:8px;margin-left:.25rem;padding:.4rem .75rem;font-size:.85rem;transition:border-color .15s,color .15s,background .15s}.logout[data-v-2ff65ce9]:hover{border-color:var(--color-border-hover);color:var(--color-text);background:var(--color-background-soft)}.main[data-v-2ff65ce9]{flex:1;width:100%;max-width:960px;margin:0 auto;padding:1.75rem 1.5rem 3rem}
