@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--color-primary: #6c5ce7;--color-primary-light: #a29bfe;--color-primary-dark: #4a3fb5;--color-primary-glow: rgba(108, 92, 231, .4);--color-accent-cyan: #00cec9;--color-accent-pink: #fd79a8;--color-accent-orange: #fdcb6e;--color-accent-green: #00b894;--color-accent-red: #e17055;--color-accent-blue: #74b9ff;--bg-primary: #0a0a1a;--bg-secondary: #12122a;--bg-tertiary: #1a1a3e;--bg-card: rgba(26, 26, 62, .6);--bg-card-hover: rgba(40, 40, 80, .8);--bg-glass: rgba(255, 255, 255, .03);--bg-glass-hover: rgba(255, 255, 255, .06);--text-primary: #f0f0ff;--text-secondary: #a0a0c0;--text-tertiary: #6a6a8e;--text-accent: #6c5ce7;--border-primary: rgba(108, 92, 231, .2);--border-secondary: rgba(255, 255, 255, .06);--border-glow: rgba(108, 92, 231, .5);--gradient-primary: linear-gradient(135deg, #6c5ce7, #a29bfe);--gradient-accent: linear-gradient(135deg, #00cec9, #6c5ce7);--gradient-warm: linear-gradient(135deg, #fdcb6e, #e17055);--gradient-cool: linear-gradient(135deg, #74b9ff, #6c5ce7);--gradient-success: linear-gradient(135deg, #00b894, #00cec9);--gradient-bg: linear-gradient(180deg, #0a0a1a 0%, #12122a 50%, #1a1a3e 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--color-primary-glow);--shadow-glow-sm: 0 0 10px var(--color-primary-glow);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 50%;--font-xs: .75rem;--font-sm: .85rem;--font-md: 1rem;--font-lg: 1.2rem;--font-xl: 1.5rem;--font-2xl: 2rem;--font-3xl: 2.5rem;--font-4xl: 3.5rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea,select{font-family:inherit;outline:none}ul,ol{list-style:none}.glass-card{background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.glass-card:hover{background:var(--bg-card-hover);border-color:var(--border-primary);box-shadow:var(--shadow-glow-sm)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--gradient-primary);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{display:inline-flex;align-items:center;gap:var(--space-sm);background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-secondary);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-primary)}.input-field{width:100%;background:var(--bg-glass);border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--text-primary);font-size:var(--font-sm);transition:all var(--transition-normal)}.input-field:focus{border-color:var(--color-primary);box-shadow:var(--shadow-glow-sm)}.input-field::placeholder{color:var(--text-tertiary)}.sort-bar{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.sort-bar-label{font-size:var(--font-xs);color:var(--text-secondary);white-space:nowrap;font-weight:500}.sort-select{background:var(--bg-glass);border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--space-xs) var(--space-md);color:var(--text-primary);font-size:var(--font-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast);appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='%23a0a0c0'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}.sort-select:hover{border-color:var(--color-primary)}.sort-select:focus{border-color:var(--color-primary);box-shadow:var(--shadow-glow-sm)}.sort-select option{background:var(--bg-secondary);color:var(--text-primary)}.progress-controls{display:flex;flex-direction:column;gap:0}.drag-wrapper{transition:transform var(--transition-fast),box-shadow var(--transition-fast);border-radius:var(--radius-lg)}.drag-wrapper.draggable{cursor:grab}.drag-wrapper.draggable:active{cursor:grabbing}.drag-wrapper.drag-over{outline:2px dashed var(--color-primary-light);outline-offset:4px;border-radius:var(--radius-lg);background:#6c5ce70d}.drag-hint{font-size:var(--font-xs);color:var(--text-tertiary);font-style:italic;animation:pulse 2s ease-in-out infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--color-primary-glow)}50%{box-shadow:0 0 20px var(--color-primary-glow),0 0 40px #6c5ce733}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes progressFill{0%{width:0%}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-slide-up{animation:slideInUp .5s ease forwards}.animate-scale-in{animation:scaleIn .3s ease forwards}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-dark)}.page-title{font-size:var(--font-2xl);font-weight:800;margin-bottom:var(--space-xs)}.page-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-xl)}@media(max-width:768px){:root{--sidebar-width: 0px;--header-height: 56px}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-secondary);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-normal)}.sidebar-logo{padding:var(--space-lg) var(--space-lg);border-bottom:1px solid var(--border-secondary);display:flex;align-items:center;gap:var(--space-md)}.sidebar-logo-icon{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:var(--shadow-glow-sm)}.sidebar-logo-text{font-size:var(--font-lg);font-weight:800;letter-spacing:-.5px}.sidebar-logo-text span{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:var(--space-lg) var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;transition:all var(--transition-normal);cursor:pointer;text-decoration:none;position:relative;overflow:hidden}.sidebar-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gradient-primary);border-radius:0 2px 2px 0;opacity:0;transition:opacity var(--transition-normal)}.sidebar-nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:#6c5ce71a;color:var(--color-primary-light)}.sidebar-nav-item.active:before{opacity:1}.sidebar-nav-icon{font-size:1.2rem;width:24px;text-align:center}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-secondary)}.sidebar-footer-text{font-size:var(--font-xs);color:var(--text-tertiary);text-align:center}.sidebar-toggle{display:none;position:fixed;top:var(--space-md);left:var(--space-md);z-index:101;background:var(--bg-secondary);border:1px solid var(--border-secondary);padding:var(--space-sm);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.2rem;cursor:pointer}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:99}}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:#0a0a1acc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-secondary);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);z-index:50}.header-left{display:flex;align-items:center;gap:var(--space-md)}.header-greeting{font-size:var(--font-md);font-weight:600}.header-greeting span{color:var(--text-secondary);font-weight:400;font-size:var(--font-sm);margin-left:var(--space-sm)}.header-right{display:flex;align-items:center;gap:var(--space-md)}.header-date{font-size:var(--font-sm);color:var(--text-secondary);background:var(--bg-glass);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-secondary)}.header-avatar{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:700;color:#fff;box-shadow:var(--shadow-glow-sm)}.header-avatar-img{width:36px;height:36px;border-radius:var(--radius-full);object-fit:cover;border:2px solid var(--border-primary);box-shadow:var(--shadow-glow-sm)}.header-logout-btn{background:var(--bg-glass);border:1px solid var(--border-secondary);color:var(--text-secondary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.header-logout-btn:hover{background:#e170551a;border-color:var(--color-accent-red);color:var(--color-accent-red)}@media(max-width:768px){.header{left:0;padding:0 var(--space-md);padding-left:56px}.header-greeting span,.header-logout-btn{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-bg);padding:var(--space-lg)}.login-card{width:100%;max-width:440px;padding:var(--space-2xl);text-align:center;animation:scaleIn .4s ease}.login-logo{width:72px;height:72px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto var(--space-lg);box-shadow:var(--shadow-glow);animation:float 3s ease-in-out infinite}.login-title{font-size:var(--font-2xl);font-weight:800;margin-bottom:var(--space-xs)}.login-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-2xl)}.login-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#fff;color:#333;border:none;border-radius:var(--radius-md);font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md)}.login-google-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.login-google-btn:active{transform:translateY(0)}.login-google-icon{width:22px;height:22px}.login-error{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:#e170551a;border:1px solid rgba(225,112,85,.3);border-radius:var(--radius-md);color:var(--color-accent-red);font-size:var(--font-sm)}.login-footer{margin-top:var(--space-2xl);font-size:var(--font-xs);color:var(--text-tertiary)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);color:var(--text-secondary);font-size:var(--font-sm)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-secondary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.public-profile{min-height:100vh;background:var(--gradient-bg);padding:var(--space-xl);animation:fadeIn .4s ease}.public-profile-container{max-width:900px;margin:0 auto}.public-header{text-align:center;margin-bottom:var(--space-2xl);padding:var(--space-2xl);animation:slideInUp .5s ease}.public-header-logo{width:64px;height:64px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto var(--space-lg);box-shadow:var(--shadow-glow);animation:float 3s ease-in-out infinite}.public-header-avatar{width:80px;height:80px;border-radius:var(--radius-full);object-fit:cover;margin:0 auto var(--space-lg);display:block;border:3px solid var(--color-primary);box-shadow:var(--shadow-glow);animation:float 3s ease-in-out infinite}.public-header-title{font-size:var(--font-3xl);font-weight:900;margin-bottom:var(--space-xs)}.public-header-subtitle{font-size:var(--font-md);color:var(--text-secondary)}.public-header-badge{display:inline-flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-xs) var(--space-md);background:#00b8941a;border:1px solid rgba(0,184,148,.3);border-radius:var(--radius-md);color:var(--color-accent-green);font-size:var(--font-xs);font-weight:600}.public-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-2xl)}.public-stat-card{padding:var(--space-lg);text-align:center;animation:fadeIn .5s ease forwards;opacity:0}.public-stat-value{font-size:var(--font-2xl);font-weight:800}.public-stat-label{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.public-section-title{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.public-radar-section{margin-bottom:var(--space-2xl)}.public-radar-card{padding:var(--space-lg);display:flex;flex-direction:column;align-items:center}.public-skill-bars{width:100%;margin-top:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.public-skill-row{display:flex;align-items:center;gap:var(--space-md)}.public-skill-label{width:140px;font-size:var(--font-sm);display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.public-skill-track{flex:1;height:8px;background:var(--bg-glass);border-radius:4px;overflow:hidden}.public-skill-fill{height:100%;border-radius:4px;transition:width 1.5s ease;animation:progressFill 1.5s ease}.public-skill-value{width:45px;font-size:var(--font-sm);font-weight:700;text-align:right}.public-progress-section{margin-bottom:var(--space-2xl)}.public-category-progress{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.public-category-card{padding:var(--space-lg);animation:fadeIn .5s ease forwards;opacity:0}.public-category-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.public-category-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.public-category-card-name{font-size:var(--font-md);font-weight:700}.public-category-card-stats{display:flex;gap:var(--space-lg);font-size:var(--font-xs);color:var(--text-secondary)}.public-recent-logs{display:flex;flex-direction:column;gap:var(--space-sm)}.public-log-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-secondary);animation:slideInUp .4s ease forwards;opacity:0}.public-log-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.public-log-content{flex:1;min-width:0}.public-log-title{font-size:var(--font-sm);font-weight:600}.public-log-meta{display:flex;gap:var(--space-md);font-size:var(--font-xs);color:var(--text-secondary);margin-top:2px}.public-log-category-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:1px 6px;border-radius:var(--radius-sm);font-size:var(--font-xs)}.public-footer{text-align:center;padding:var(--space-xl);color:var(--text-tertiary);font-size:var(--font-xs);border-top:1px solid var(--border-secondary);margin-top:var(--space-2xl)}.public-footer a{color:var(--color-primary-light)}.share-link-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-glass);border:1px solid var(--border-secondary);color:var(--text-secondary);border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.share-link-btn:hover{background:var(--bg-glass-hover);border-color:var(--color-accent-cyan);color:var(--color-accent-cyan)}.share-link-btn.copied{border-color:var(--color-accent-green);color:var(--color-accent-green);background:#00b8941a}@media(max-width:768px){.public-profile{padding:var(--space-md)}.public-header-title{font-size:var(--font-2xl)}.public-skill-label{width:100px;font-size:var(--font-xs)}}.stats-card{padding:var(--space-lg);position:relative;overflow:hidden;animation:fadeIn .5s ease forwards;opacity:0}.stats-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stats-card.purple:before{background:var(--gradient-primary)}.stats-card.cyan:before{background:var(--gradient-accent)}.stats-card.warm:before{background:var(--gradient-warm)}.stats-card.green:before{background:var(--gradient-success)}.stats-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.stats-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;background:var(--bg-glass);border:1px solid var(--border-secondary)}.stats-card-trend{font-size:var(--font-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-sm)}.stats-card-trend.up{color:var(--color-accent-green);background:#00b8941a}.stats-card-trend.down{color:var(--color-accent-red);background:#e170551a}.stats-card-value{font-size:var(--font-2xl);font-weight:800;line-height:1.2;margin-bottom:var(--space-xs)}.stats-card-label{font-size:var(--font-sm);color:var(--text-secondary)}.activity-feed{padding:var(--space-lg);animation:fadeIn .5s ease .2s forwards;opacity:0}.activity-feed-title{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.activity-feed-list{display:flex;flex-direction:column;gap:var(--space-sm)}.activity-feed-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-secondary);transition:all var(--transition-normal)}.activity-feed-item:hover{background:var(--bg-glass-hover);border-color:var(--border-primary)}.activity-feed-item-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.activity-feed-item-content{flex:1;min-width:0}.activity-feed-item-title{font-size:var(--font-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-feed-item-meta{display:flex;gap:var(--space-md);font-size:var(--font-xs);color:var(--text-secondary);margin-top:2px}.activity-feed-empty{text-align:center;padding:var(--space-xl);color:var(--text-tertiary);font-size:var(--font-sm)}.progress-chart{padding:var(--space-lg);animation:fadeIn .5s ease .15s forwards;opacity:0}.progress-chart-title{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.progress-chart-bars{display:flex;flex-direction:column;gap:var(--space-md)}.progress-bar-row{display:flex;align-items:center;gap:var(--space-md)}.progress-bar-label{width:130px;font-size:var(--font-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.progress-bar-track{flex:1;height:10px;background:var(--bg-glass);border-radius:5px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;border-radius:5px;transition:width 1s ease;animation:progressFill 1.2s ease;position:relative}.progress-bar-fill:after{content:"";position:absolute;top:0;right:0;width:15px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3));border-radius:0 5px 5px 0}.progress-bar-value{width:60px;font-size:var(--font-sm);font-weight:600;text-align:right;flex-shrink:0}.category-tabs{margin-top:var(--space-xl);animation:fadeIn .4s ease .3s forwards;opacity:0}.category-tabs-title{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.category-tabs-bar{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap}.category-tab-btn{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-secondary);color:var(--text-secondary);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.category-tab-btn:hover{background:var(--bg-glass-hover);border-color:var(--border-primary);transform:translateY(-1px)}.category-tab-btn.active{border-color:var(--tab-color, var(--color-primary));background:color-mix(in srgb,var(--tab-color, var(--color-primary)) 12%,transparent);color:var(--text-primary);box-shadow:0 0 12px color-mix(in srgb,var(--tab-color, var(--color-primary)) 30%,transparent)}.category-tab-icon{font-size:1.1rem}.category-tab-panel{padding:var(--space-lg);animation:scaleIn .3s ease}.category-tab-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-secondary)}.category-tab-panel-info{display:flex;align-items:center;gap:var(--space-md)}.category-tab-panel-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.category-tab-panel-name{font-size:var(--font-lg);font-weight:700}.category-tab-panel-desc{font-size:var(--font-xs);color:var(--text-tertiary);margin-top:2px}.category-tab-panel-stats{display:flex;gap:var(--space-xl);text-align:center}.category-tab-stat{display:flex;flex-direction:column;align-items:center}.category-tab-stat-value{font-size:var(--font-xl);font-weight:800}.category-tab-stat-label{font-size:var(--font-xs);color:var(--text-tertiary)}.category-tab-logs{display:flex;flex-direction:column;gap:var(--space-sm)}.category-tab-log-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-secondary);transition:all var(--transition-normal);animation:slideInUp .3s ease forwards;opacity:0}.category-tab-log-item:hover{background:var(--bg-glass-hover);border-color:var(--border-primary)}.category-tab-log-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.category-tab-log-content{flex:1;min-width:0}.category-tab-log-title{font-size:var(--font-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-tab-log-desc{font-size:var(--font-xs);color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-tab-log-meta{display:flex;gap:var(--space-md);font-size:var(--font-xs);color:var(--text-secondary);flex-shrink:0}.category-tab-empty{text-align:center;padding:var(--space-xl);color:var(--text-tertiary);font-size:var(--font-sm)}@media(max-width:768px){.category-tab-panel-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.category-tab-log-meta{flex-direction:column;gap:var(--space-xs)}}.dashboard-page{animation:fadeIn .4s ease}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.category-card{padding:var(--space-lg);cursor:pointer;position:relative;overflow:hidden;transition:all var(--transition-normal);animation:fadeIn .5s ease forwards;opacity:0}.category-card:before{content:"";position:absolute;top:0;left:0;bottom:0;width:4px}.category-card:hover{transform:translateY(-3px)}.category-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.category-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.category-card-actions{display:flex;gap:var(--space-xs)}.category-card-action-btn{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-secondary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.category-card-action-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.category-card-action-btn.delete:hover{color:var(--color-accent-red);border-color:var(--color-accent-red)}.category-card-action-btn.edit:hover{color:var(--color-primary-light);border-color:var(--color-primary-light)}.category-card-name{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-xs)}.category-card-desc{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-md)}.category-card-stats{display:flex;gap:var(--space-lg);font-size:var(--font-xs);color:var(--text-tertiary)}.category-card-stats span{display:flex;align-items:center;gap:var(--space-xs)}.category-form-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.category-form{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:480px;animation:scaleIn .3s ease}.category-form-title{font-size:var(--font-xl);font-weight:700;margin-bottom:var(--space-lg)}.category-form-group{margin-bottom:var(--space-md)}.category-form-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.category-form-icon-picker{display:flex;gap:var(--space-sm);flex-wrap:wrap}.category-form-icon-option{width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-glass);border:2px solid var(--border-secondary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all var(--transition-fast)}.category-form-icon-option:hover{border-color:var(--color-primary)}.category-form-icon-option.selected{border-color:var(--color-primary);background:#6c5ce726;box-shadow:var(--shadow-glow-sm)}.category-form-color-picker{display:flex;gap:var(--space-sm)}.category-form-color-option{width:32px;height:32px;border-radius:var(--radius-full);border:3px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.category-form-color-option:hover{transform:scale(1.15)}.category-form-color-option.selected{border-color:#fff;box-shadow:0 0 10px currentColor}.category-form-actions{display:flex;gap:var(--space-md);margin-top:var(--space-xl)}.category-form-actions button{flex:1}.categories-page{animation:fadeIn .4s ease}.categories-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.categories-empty{text-align:center;padding:var(--space-3xl);color:var(--text-tertiary)}.categories-empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.log-entry{display:flex;gap:var(--space-md);padding:var(--space-lg);animation:slideInUp .4s ease forwards;opacity:0}.log-entry-timeline{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.log-entry-dot{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}.log-entry-line{width:2px;flex:1;background:var(--border-secondary);min-height:20px}.log-entry-content{flex:1;min-width:0}.log-entry-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.log-entry-title{font-size:var(--font-md);font-weight:700}.log-entry-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.log-entry-edit,.log-entry-delete{width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all var(--transition-fast)}.log-entry-edit:hover{color:var(--color-primary-light);background:#6c5ce71a}.log-entry-delete:hover{color:var(--color-accent-red);background:#e170551a}.log-entry-desc{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-sm);line-height:1.5}.log-entry-meta{display:flex;gap:var(--space-md);font-size:var(--font-xs);color:var(--text-tertiary)}.log-entry-meta span{display:flex;align-items:center;gap:var(--space-xs)}.log-entry-category-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:500}.log-form-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.log-form{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:500px;animation:scaleIn .3s ease}.log-form-title{font-size:var(--font-xl);font-weight:700;margin-bottom:var(--space-lg)}.log-form-group{margin-bottom:var(--space-md)}.log-form-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.log-form-row{display:flex;gap:var(--space-md)}.log-form-row .log-form-group{flex:1}.log-form select.input-field{appearance:none;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='%23a0a0c0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.log-form textarea.input-field{resize:vertical;min-height:80px}.log-form-actions{display:flex;gap:var(--space-md);margin-top:var(--space-xl)}.log-form-actions button{flex:1}.progress-page{animation:fadeIn .4s ease}.progress-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.progress-page-filters{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap}.progress-filter-btn{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:500;background:var(--bg-glass);border:1px solid var(--border-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.progress-filter-btn:hover{background:var(--bg-glass-hover)}.progress-filter-btn.active{background:#6c5ce726;border-color:var(--color-primary);color:var(--color-primary-light)}.progress-log-list{display:flex;flex-direction:column}.progress-empty{text-align:center;padding:var(--space-3xl);color:var(--text-tertiary)}.progress-empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.radar-chart-container{padding:var(--space-lg);display:flex;flex-direction:column;align-items:center;animation:fadeIn .5s ease forwards;opacity:0}.radar-chart-title{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-lg);align-self:flex-start;display:flex;align-items:center;gap:var(--space-sm)}.radar-chart-canvas{max-width:100%}.radar-chart-legend{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-lg);justify-content:center}.radar-chart-legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-xs);color:var(--text-secondary)}.radar-chart-legend-dot{width:10px;height:10px;border-radius:var(--radius-full)}.skill-level-list{width:100%;margin-top:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-md)}.skill-level-row{display:flex;align-items:center;gap:var(--space-md)}.skill-level-label{width:140px;font-size:var(--font-sm);display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.skill-level-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;background:var(--bg-glass);border-radius:3px;outline:none}.skill-level-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:var(--radius-full);background:var(--gradient-primary);cursor:pointer;box-shadow:var(--shadow-glow-sm);transition:transform var(--transition-fast)}.skill-level-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.skill-level-value{width:45px;font-size:var(--font-sm);font-weight:700;text-align:right}.skills-page{animation:fadeIn .4s ease}.skills-page-content{max-width:700px}.goal-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-secondary);transition:all var(--transition-normal);animation:slideInUp .4s ease forwards;opacity:0}.goal-item:hover{background:var(--bg-glass-hover);border-color:var(--border-primary)}.goal-item.completed{opacity:.7}.goal-item-check{width:24px;height:24px;border-radius:var(--radius-sm);border:2px solid var(--border-secondary);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:transparent;transition:all var(--transition-normal);flex-shrink:0}.goal-item-check:hover{border-color:var(--color-accent-green)}.goal-item.completed .goal-item-check{background:var(--color-accent-green);border-color:var(--color-accent-green);color:#fff}.goal-item-content{flex:1;min-width:0}.goal-item-title{font-size:var(--font-sm);font-weight:600}.goal-item.completed .goal-item-title{text-decoration:line-through;color:var(--text-tertiary)}.goal-item-category{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-xs);color:var(--text-tertiary);margin-top:2px}.goal-item-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.goal-item-edit,.goal-item-delete{width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all var(--transition-fast);flex-shrink:0}.goal-item-edit:hover{color:var(--color-primary-light);background:#6c5ce71a}.goal-item-delete:hover{color:var(--color-accent-red);background:#e170551a}.goal-form-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.goal-form{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:480px;animation:scaleIn .3s ease}.goal-form-title{font-size:var(--font-xl);font-weight:700;margin-bottom:var(--space-lg)}.goal-form-group{margin-bottom:var(--space-md)}.goal-form-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.goal-form select.input-field{appearance:none;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='%23a0a0c0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.goal-form-actions{display:flex;gap:var(--space-md);margin-top:var(--space-xl)}.goal-form-actions button{flex:1}.goals-page{animation:fadeIn .4s ease}.goals-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.goals-summary{display:flex;gap:var(--space-lg);margin-bottom:var(--space-xl)}.goals-summary-card{padding:var(--space-lg);flex:1;text-align:center}.goals-summary-value{font-size:var(--font-2xl);font-weight:800;margin-bottom:var(--space-xs)}.goals-summary-label{font-size:var(--font-sm);color:var(--text-secondary)}.goals-progress-bar{margin-bottom:var(--space-xl)}.goals-progress-header{display:flex;justify-content:space-between;margin-bottom:var(--space-sm);font-size:var(--font-sm)}.goals-progress-track{height:10px;background:var(--bg-glass);border-radius:5px;overflow:hidden}.goals-progress-fill{height:100%;border-radius:5px;background:var(--gradient-success);transition:width .5s ease;animation:progressFill 1s ease}.goals-list{display:flex;flex-direction:column;gap:var(--space-sm);max-width:700px}.goals-empty{text-align:center;padding:var(--space-3xl);color:var(--text-tertiary)}.goals-empty-icon{font-size:3rem;margin-bottom:var(--space-md)}@media(max-width:768px){.goals-summary{flex-direction:column}}.app-layout{display:flex;min-height:100vh;background:var(--gradient-bg)}.app-main{flex:1;margin-left:var(--sidebar-width);padding-top:var(--header-height)}.app-content{padding:var(--space-xl);max-width:1200px;min-height:calc(100vh - var(--header-height))}@media(max-width:768px){.app-main{margin-left:0}.app-content{padding:var(--space-md)}}
