@import"https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap";:root{--color-accent: #bff66f;--color-accent-dark: #a8dc5a;--color-accent-light: #d4faa0;--color-bg: #ffffff;--color-bg-card: #f5f5f4;--color-bg-input: #fafaf9;--color-bg-overlay: rgba(0, 0, 0, .45);--color-text: #000000;--color-text-card: #57534e;--color-text-muted: #78716c;--color-text-on-accent:#1a1a1a;--color-border: #e7e5e4;--color-border-focus: #bff66f;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-warning: #d97706;--color-warning-bg: #fffbeb;--font-sans: "Geist", system-ui, -apple-system, sans-serif;--font-mono: "Geist Mono", "Fira Code", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--weight-regular: 400;--weight-medium: 500;--weight-semibold:600;--weight-bold: 700;--leading-tight: 1.2;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed:1.625;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full:9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.08);--shadow-sm: 0 2px 4px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.09);--shadow-md: 0 4px 8px rgba(0,0,0,.08), 0 6px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 16px rgba(0,0,0,.09), 0 12px 32px rgba(0,0,0,.12);--shadow-xl: 0 16px 32px rgba(0,0,0,.1), 0 24px 56px rgba(0,0,0,.14);--shadow-accent: 0 4px 16px rgba(191,246,111,.35);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--container-max: 1200px;--sidebar-width: 220px;--header-height: 60px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--weight-regular);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{line-height:var(--leading-relaxed);color:var(--color-text-card)}a{color:var(--color-text);text-decoration:none;font-weight:var(--weight-medium);transition:color var(--transition-fast)}a:hover{color:var(--color-accent-dark)}ul,ol{list-style:none}img,svg{display:block;max-width:100%}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none}input,textarea,select{font-family:var(--font-sans);font-size:var(--text-base)}code,kbd,samp,pre{font-family:var(--font-mono);font-size:var(--text-sm)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.font-regular{font-weight:var(--weight-regular)}.font-medium{font-weight:var(--weight-medium)}.font-semibold{font-weight:var(--weight-semibold)}.font-bold{font-weight:var(--weight-bold)}.font-mono{font-family:var(--font-mono)}.text-muted{color:var(--color-text-muted)}.text-card{color:var(--color-text-card)}.text-accent{color:var(--color-accent-dark)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.text-center{text-align:center}.text-right{text-align:right}.badge{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);background-color:var(--color-bg-card);color:var(--color-text-card);border:1px solid var(--color-border)}.badge--accent{background-color:var(--color-accent);color:var(--color-text-on-accent);border-color:var(--color-accent)}.badge--success{background-color:var(--color-success-bg);color:var(--color-success);border-color:currentColor}.badge--error{background-color:var(--color-error-bg);color:var(--color-error);border-color:currentColor}.badge--warning{background-color:var(--color-warning-bg);color:var(--color-warning);border-color:currentColor}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:1;border-radius:var(--radius-md);border:1.5px solid transparent;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast);white-space:nowrap;text-decoration:none;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn--primary{background-color:var(--color-accent);color:var(--color-text-on-accent);border-color:var(--color-accent)}.btn--primary:hover{background-color:var(--color-accent-dark);border-color:var(--color-accent-dark);box-shadow:var(--shadow-accent)}.btn--primary:active{background-color:var(--color-accent-dark);box-shadow:none}.btn--secondary{background-color:var(--color-bg);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover{background-color:var(--color-bg-card);border-color:var(--color-text-muted);box-shadow:var(--shadow-sm)}.btn--ghost{background-color:transparent;color:var(--color-text-card);border-color:transparent}.btn--ghost:hover{background-color:var(--color-bg-card);color:var(--color-text)}.btn--danger{background-color:var(--color-bg);color:var(--color-error);border-color:var(--color-error)}.btn--danger:hover{background-color:var(--color-error-bg);box-shadow:0 2px 8px #dc262633}.btn--sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn--lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-lg)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text);cursor:pointer}.form-input,.form-textarea,.form-select{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text);background-color:var(--color-bg-input);border:1.5px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);appearance:none;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted);font-weight:var(--weight-regular)}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--color-text-muted)}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-accent);background-color:var(--color-bg);box-shadow:0 0 0 3px #bff66f40}.form-textarea{min-height:100px;resize:vertical;line-height:var(--leading-relaxed)}.form-select{padding-right:var(--space-8);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2378716c' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;cursor:pointer}.form-input--error,.form-textarea--error,.form-select--error{border-color:var(--color-error)}.form-input--error:focus,.form-textarea--error:focus{box-shadow:0 0 0 3px #dc262626}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-snug)}.form-hint--error{color:var(--color-error)}.form-checkbox{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.form-checkbox__input{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}.form-checkbox__label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text)}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);color:var(--color-text-card);box-shadow:var(--shadow-xs)}.card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.card__title{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--color-text);line-height:var(--leading-snug)}.card__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.card__body{font-size:var(--text-sm);line-height:var(--leading-relaxed)}.card__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.card__meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.card--elevated{box-shadow:var(--shadow-md)}.card--interactive{text-decoration:none;display:block;cursor:pointer;transition:box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base)}.card--interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-accent)}.card--interactive:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.card--accent{border-left:4px solid var(--color-accent)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:var(--leading-snug);border:1px solid transparent}.alert--error{background-color:var(--color-error-bg);color:var(--color-error);border-color:#dc262633}.alert--success{background-color:var(--color-success-bg);color:var(--color-success);border-color:#16a34a33}.alert--warning{background-color:var(--color-warning-bg);color:var(--color-warning);border-color:#d9770633}.alert--info{background-color:var(--color-bg-card);color:var(--color-text-card);border-color:var(--color-border)}.dialog-overlay{position:fixed;inset:0;background-color:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.dialog{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:420px;box-shadow:var(--shadow-xl)}.dialog__title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-text);margin-bottom:var(--space-3)}.dialog__body{font-size:var(--text-sm);color:var(--color-text-card);line-height:var(--leading-relaxed);margin-bottom:var(--space-6)}.dialog__actions{display:flex;gap:var(--space-3);justify-content:flex-end}.skill-tag{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-medium);background-color:var(--color-bg-card);color:var(--color-text-card);border:1px solid var(--color-border);border-radius:var(--radius-full);white-space:nowrap}.skill-tag__level{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted)}.skill-tag--accent{background-color:#bff66f26;border-color:var(--color-accent);color:#3d6b00}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background-color:var(--color-bg)}.auth-card{width:100%;max-width:420px;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);box-shadow:var(--shadow-xl)}.auth-card__brand{text-align:center;margin-bottom:var(--space-8)}.auth-card__logo{font-size:var(--text-2xl);font-weight:var(--weight-bold);letter-spacing:-.03em;color:var(--color-text)}.auth-card__logo span{color:var(--color-accent-dark)}.auth-card__title{font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.auth-card__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-6);line-height:var(--leading-snug)}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.auth-form__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-2);flex-wrap:wrap}.auth-form__link{font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none;font-weight:var(--weight-medium);transition:color var(--transition-fast)}.auth-form__link:hover{color:var(--color-accent-dark)}.auth-confirmation{text-align:center;padding:var(--space-6) var(--space-4)}.auth-confirmation__icon{font-size:var(--text-4xl);margin-bottom:var(--space-4)}.auth-confirmation__text{font-size:var(--text-base);color:var(--color-text-card);line-height:var(--leading-relaxed)}.app-header{position:sticky;top:0;z-index:50;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background-color:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.app-header__brand{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text);text-decoration:none;letter-spacing:-.02em}.app-header__brand span{color:var(--color-accent-dark)}.app-header__user{display:flex;align-items:center;gap:var(--space-4)}.app-header__name{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--weight-medium)}.app-shell{display:flex;flex:1;min-height:calc(100vh - var(--header-height))}.app-sidebar{width:var(--sidebar-width);flex-shrink:0;background-color:var(--color-bg);border-right:1px solid var(--color-border);padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);position:sticky;top:var(--header-height);height:calc(100vh - var(--header-height));overflow-y:auto}.app-sidebar__link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-card);text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast)}.app-sidebar__link:hover{background-color:var(--color-bg-card);color:var(--color-text)}.app-sidebar__link--active{background-color:#bff66f26;color:#3d6b00;font-weight:var(--weight-semibold)}.app-main{flex:1;overflow-y:auto;padding:var(--space-8) var(--space-8);max-width:calc(var(--container-max) - var(--sidebar-width))}@media(max-width:768px){.app-shell{flex-direction:column}.app-sidebar{width:100%;height:auto;position:static;flex-direction:row;overflow-x:auto;padding:var(--space-3) var(--space-4);border-right:none;border-bottom:1px solid var(--color-border);gap:var(--space-1)}.app-main{padding:var(--space-5) var(--space-4)}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap}.page-title{font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--color-text);letter-spacing:-.02em;line-height:var(--leading-tight)}.page-subtitle{font-size:var(--text-base);color:var(--color-text-muted);margin-top:var(--space-2);font-weight:var(--weight-regular)}.section{margin-bottom:var(--space-10)}.section__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5)}.section__title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-text)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.item-list{display:flex;flex-direction:column;gap:var(--space-3)}.toolbar{display:flex;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.toolbar__group{display:flex;flex-direction:column;gap:var(--space-2);min-width:160px}.empty-state{text-align:center;padding:var(--space-16) var(--space-6);color:var(--color-text-muted)}.empty-state__text{font-size:var(--text-base);color:var(--color-text-muted)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-12);color:var(--color-text-muted);font-size:var(--text-sm)}.score{font-family:var(--font-mono);font-weight:var(--weight-medium);font-size:var(--text-sm);color:var(--color-accent-dark)}.divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-6) 0}
