:root{--vt-c-white: #ffffff;--vt-c-white-soft: #f8f8f8;--vt-c-white-mute: #f2f2f2;--vt-c-black: #181818;--vt-c-black-soft: #222222;--vt-c-black-mute: #282828;--vt-c-indigo: #2c3e50;--vt-c-divider-light-1: rgba(60, 60, 60, .29);--vt-c-divider-light-2: rgba(60, 60, 60, .12);--vt-c-divider-dark-1: rgba(84, 84, 84, .65);--vt-c-divider-dark-2: rgba(84, 84, 84, .48);--vt-c-text-light-1: var(--vt-c-indigo);--vt-c-text-light-2: rgba(60, 60, 60, .66);--vt-c-text-dark-1: var(--vt-c-white);--vt-c-text-dark-2: rgba(235, 235, 235, .64)}:root{--color-background: var(--vt-c-white);--color-background-soft: var(--vt-c-white-soft);--color-background-mute: var(--vt-c-white-mute);--color-border: var(--vt-c-divider-light-2);--color-border-hover: var(--vt-c-divider-light-1);--color-heading: var(--vt-c-text-light-1);--color-text: var(--vt-c-text-light-1);--section-gap: 160px}@media(prefers-color-scheme:dark){:root{--color-background: var(--vt-c-black);--color-background-soft: var(--vt-c-black-soft);--color-background-mute: var(--vt-c-black-mute);--color-border: var(--vt-c-divider-dark-2);--color-border-hover: var(--vt-c-divider-dark-1);--color-heading: var(--vt-c-text-dark-1);--color-text: var(--vt-c-text-dark-2)}}*,*:before,*:after{box-sizing:border-box;margin:0;font-weight:400}body{min-height:100vh;color:var(--color-text);background:var(--color-background);transition:color .5s,background-color .5s;line-height:1.6;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:15px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--ds-background: #FAFAFA;--ds-foreground: #0F172A;--ds-muted: #F1F5F9;--ds-muted-foreground: #64748B;--ds-accent: #0052FF;--ds-accent-secondary: #4D7CFF;--ds-accent-foreground: #FFFFFF;--ds-border: #E2E8F0;--ds-card: #FFFFFF;--ds-ring: #0052FF;--ds-gradient: linear-gradient(to right, var(--ds-accent), var(--ds-accent-secondary));--ds-gradient-135: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-secondary));--ds-font-display: "Calistoga", Georgia, serif;--ds-font-body: "Inter", system-ui, sans-serif;--ds-font-mono: "JetBrains Mono", monospace;--ds-text-hero: 5.25rem;--ds-text-section: 3.25rem;--ds-text-card-title: 1.5rem;--ds-text-body: 1rem;--ds-text-body-lg: 1.125rem;--ds-text-label: .75rem;--ds-leading-hero: 1.05;--ds-leading-section: 1.15;--ds-leading-body: 1.625;--ds-tracking-hero: -.02em;--ds-tracking-card: -.01em;--ds-tracking-label: .15em;--ds-container-max: 72rem;--ds-section-py: 7rem;--ds-section-py-lg: 11rem;--ds-gap-5: 1.25rem;--ds-gap-6: 1.5rem;--ds-gap-8: 2rem;--ds-radius-lg: .5rem;--ds-radius-xl: .75rem;--ds-radius-2xl: 1rem;--ds-radius-full: 9999px;--ds-shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--ds-shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--ds-shadow-lg: 0 10px 15px rgba(0, 0, 0, .08);--ds-shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--ds-shadow-accent: 0 4px 14px rgba(0, 82, 255, .25);--ds-shadow-accent-lg: 0 8px 24px rgba(0, 82, 255, .35)}.gradient-text{background:var(--ds-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}.gradient-underline{position:absolute;bottom:-.25rem;left:0;height:.75rem;width:100%;border-radius:.125rem;background:linear-gradient(to right,#0052ff26,#4d7cff1a)}@media(min-width:768px){.gradient-underline{bottom:-.5rem;height:1rem}}#app{width:100%;min-height:100vh;font-weight:400;margin:0;padding:0}a,.green{text-decoration:none;color:#00bd7e;transition:.4s;padding:3px}@media(hover:hover){a:hover{background-color:#00bd7e33}}.app-container[data-v-b64c784e]{min-height:100vh;display:flex;flex-direction:column;background:var(--ds-background)}.navbar[data-v-b64c784e]{background:var(--ds-card);border-bottom:1px solid var(--ds-border);box-shadow:var(--ds-shadow-sm);padding:0 1.5rem}.nav-content[data-v-b64c784e]{max-width:var(--ds-container-max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:3.5rem}@media(min-width:768px){.nav-content[data-v-b64c784e]{padding:0 2rem}}.nav-left[data-v-b64c784e]{display:flex;align-items:center;gap:2rem;min-width:0}.logo-link[data-v-b64c784e]{text-decoration:none;color:var(--ds-foreground);flex-shrink:0}.logo-text[data-v-b64c784e]{margin:0;font-family:var(--ds-font-display);font-size:1.25rem;font-weight:400;line-height:1.2}@media(min-width:640px){.logo-text[data-v-b64c784e]{font-size:1.5rem}}.nav-links[data-v-b64c784e]{display:flex;gap:.5rem}@media(min-width:640px){.nav-links[data-v-b64c784e]{gap:1.5rem}}.nav-link[data-v-b64c784e]{font-family:var(--ds-font-body);color:var(--ds-muted-foreground);text-decoration:none;font-size:.9375rem;font-weight:500;padding:.5rem .25rem;border-bottom:2px solid transparent;transition:color .2s ease-out,border-color .2s ease-out}.nav-link[data-v-b64c784e]:hover{color:var(--ds-foreground)}.nav-link.router-link-active[data-v-b64c784e]{color:var(--ds-accent);border-bottom-color:var(--ds-accent)}.nav-link[data-v-b64c784e]:focus-visible{outline:2px solid var(--ds-ring);outline-offset:2px;border-radius:2px}.nav-right[data-v-b64c784e]{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.user-info[data-v-b64c784e]{display:flex;align-items:center;gap:.5rem}.username[data-v-b64c784e]{font-family:var(--ds-font-body);font-weight:500;color:var(--ds-foreground);font-size:.875rem}.role-badge[data-v-b64c784e]{font-family:var(--ds-font-mono);font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:.25rem .5rem;border-radius:var(--ds-radius-full);background:#0052ff14;color:var(--ds-accent);border:1px solid rgba(0,82,255,.2)}.settings-link[data-v-b64c784e]{font-family:var(--ds-font-body);font-size:.875rem;font-weight:500;color:var(--ds-muted-foreground);text-decoration:none;padding:.5rem .75rem;border-radius:var(--ds-radius-lg);transition:color .2s ease-out,background-color .2s ease-out}.settings-link[data-v-b64c784e]:hover{color:var(--ds-foreground);background:var(--ds-muted)}.settings-link[data-v-b64c784e]:focus-visible{outline:2px solid var(--ds-ring);outline-offset:2px}.logout-btn[data-v-b64c784e]{font-family:var(--ds-font-body);font-size:.875rem;font-weight:500;min-height:2.5rem;padding:.5rem 1rem;color:var(--ds-foreground);background:transparent;border:1px solid var(--ds-border);border-radius:var(--ds-radius-lg);cursor:pointer;transition:background-color .2s ease-out,border-color .2s ease-out}.logout-btn[data-v-b64c784e]:hover{background:var(--ds-muted);border-color:#0052ff4d}.logout-btn[data-v-b64c784e]:focus-visible{outline:none;box-shadow:0 0 0 2px var(--ds-background),0 0 0 4px var(--ds-ring)}.logout-btn[data-v-b64c784e]:active{transform:scale(.98)}.main-content[data-v-b64c784e]{flex:1}.home-container[data-v-83dcfbec]{max-width:var(--ds-container-max);margin:0 auto;padding:var(--ds-section-py) 1.5rem}@media(min-width:768px){.home-container[data-v-83dcfbec]{padding-left:2rem;padding-right:2rem}}.welcome-box[data-v-83dcfbec]{background:var(--ds-card);border:1px solid var(--ds-border);border-radius:var(--ds-radius-2xl);padding:2.5rem;box-shadow:var(--ds-shadow-md);transition:box-shadow .3s ease-out}.welcome-box[data-v-83dcfbec]:hover{box-shadow:var(--ds-shadow-lg)}.page-title[data-v-83dcfbec]{font-family:var(--ds-font-display);color:var(--ds-foreground);font-size:1.75rem;font-weight:400;line-height:var(--ds-leading-section);margin:0 0 .5rem}@media(min-width:640px){.page-title[data-v-83dcfbec]{font-size:2rem}}.welcome-text[data-v-83dcfbec]{font-family:var(--ds-font-body);color:var(--ds-muted-foreground);font-size:var(--ds-text-body);line-height:var(--ds-leading-body);margin:0 0 1.5rem}.user-name[data-v-83dcfbec]{color:var(--ds-foreground);font-weight:600}.role-label[data-v-83dcfbec]{margin-left:.75rem;color:var(--ds-muted-foreground);font-weight:400}.recommendations-section[data-v-83dcfbec]{margin-top:1.5rem;padding:1.5rem;background:var(--ds-muted);border:1px solid var(--ds-border);border-radius:var(--ds-radius-xl)}.section-badge[data-v-83dcfbec]{display:inline-flex;align-items:center;gap:.75rem;border:1px solid rgba(0,82,255,.3);background:#0052ff0d;border-radius:var(--ds-radius-full);padding:.5rem 1.25rem;margin-bottom:1rem}.section-badge-dot[data-v-83dcfbec]{width:.5rem;height:.5rem;border-radius:50%;background:var(--ds-accent);flex-shrink:0}.section-badge-text[data-v-83dcfbec]{font-family:var(--ds-font-body);font-size:.95rem;font-weight:500;letter-spacing:var(--ds-tracking-label);color:var(--ds-accent)}.recommendations-loading[data-v-83dcfbec],.recommendations-error[data-v-83dcfbec]{font-family:var(--ds-font-body);text-align:center;padding:1rem;color:var(--ds-muted-foreground)}.recommendations-error[data-v-83dcfbec]{color:#b91c1c}.recommendations-empty[data-v-83dcfbec]{font-family:var(--ds-font-body);padding:1rem 0;color:var(--ds-muted-foreground);font-size:.95rem}.recommendations-empty a[data-v-83dcfbec]{color:var(--ds-accent);font-weight:600;text-decoration:none}.recommendations-empty a[data-v-83dcfbec]:hover{text-decoration:underline}.recommendations-split[data-v-83dcfbec]{display:flex;flex-direction:column;gap:1.5rem}.recommendations-subtitle[data-v-83dcfbec]{font-family:var(--ds-font-body);font-size:.95rem;font-weight:600;color:var(--ds-foreground);margin:0 0 .75rem}.recommendations-cards-row[data-v-83dcfbec]{display:flex;flex-direction:row;flex-wrap:wrap;gap:.75rem}.recommendations-cards-row .recommendation-card[data-v-83dcfbec]{flex:1 1 280px;min-width:0;max-width:100%}@media(min-width:640px){.recommendations-cards-row .recommendation-card[data-v-83dcfbec]{flex:1 1 300px;max-width:400px}}.recommendation-card[data-v-83dcfbec]{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem;background:var(--ds-card);border:1px solid var(--ds-border);border-radius:var(--ds-radius-xl);cursor:pointer;box-shadow:var(--ds-shadow-sm);transition:transform .2s ease-out,box-shadow .2s ease-out,border-color .2s ease-out}.recommendation-card[data-v-83dcfbec]:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-xl);border-color:var(--ds-border)}.recommendation-card[data-v-83dcfbec]:focus-visible{outline:none;box-shadow:0 0 0 2px var(--ds-background),0 0 0 4px var(--ds-ring)}.rec-main[data-v-83dcfbec]{display:flex;flex-direction:column;gap:.25rem}.rec-title[data-v-83dcfbec]{font-family:var(--ds-font-body);font-weight:600;color:var(--ds-foreground);font-size:1rem;letter-spacing:var(--ds-tracking-card)}.rec-course[data-v-83dcfbec]{font-family:var(--ds-font-body);font-size:.875rem;color:var(--ds-muted-foreground)}.rec-meta[data-v-83dcfbec]{display:flex;align-items:center;gap:1rem;font-family:var(--ds-font-body);font-size:.875rem;color:var(--ds-muted-foreground)}.rec-kp[data-v-83dcfbec]{color:var(--ds-foreground)}.rec-due[data-v-83dcfbec]{color:var(--ds-muted-foreground)}.rec-action[data-v-83dcfbec]{font-family:var(--ds-font-body);font-size:.9rem;font-weight:500;color:var(--ds-accent);flex-shrink:0;transition:transform .2s ease-out}.recommendation-card:hover .rec-action[data-v-83dcfbec]{transform:translate(4px)}.quick-entries[data-v-83dcfbec]{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--ds-border)}.quick-entries-title[data-v-83dcfbec]{font-family:var(--ds-font-body);font-size:1rem;font-weight:600;color:var(--ds-foreground);margin:0 0 1rem}.quick-entries-grid[data-v-83dcfbec]{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.quick-entry-card[data-v-83dcfbec]{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.25rem;background:var(--ds-muted);border:1px solid var(--ds-border);border-radius:var(--ds-radius-xl);text-decoration:none;color:var(--ds-foreground);transition:background-color .2s ease-out,border-color .2s ease-out,box-shadow .2s ease-out}.quick-entry-card[data-v-83dcfbec]:hover{background:var(--ds-card);border-color:#0052ff40;box-shadow:var(--ds-shadow-sm)}.quick-entry-label[data-v-83dcfbec]{font-family:var(--ds-font-body);font-weight:600;font-size:1rem}.quick-entry-desc[data-v-83dcfbec]{font-family:var(--ds-font-body);font-size:.875rem;color:var(--ds-muted-foreground)}
