:root{--bg-primary: #080c14;--bg-secondary: #0f1625;--bg-card: rgba(255, 255, 255, .04);--bg-card-hover: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .08);--border-focus: rgba(77, 168, 218, .4);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #4da8da;--accent-2: #6366f1;--accent-gradient: linear-gradient(135deg, #4da8da, #6366f1);--accent-gradient-reverse: linear-gradient(135deg, #6366f1, #4da8da);--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 24px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .4);--max-width: 1200px;--header-height: 60px;--transition: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:#6dbde4}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit;border:none;outline:none}input,textarea,select{font-family:inherit;font-size:inherit}#app{max-width:var(--max-width);margin:0 auto;padding:0 24px 60px}.top-bar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100;background:#080c14d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);margin:0 -24px;padding:16px 24px}.top-bar-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.top-bar-title em{font-style:normal;font-weight:400;color:var(--text-muted)}.top-bar-nav{display:flex;align-items:center;gap:4px;margin:0 auto;flex-shrink:0}.top-bar-nav a{padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-muted);text-decoration:none;transition:all var(--transition);white-space:nowrap}.top-bar-nav a:hover,.top-bar-nav a.active{color:var(--accent);background:#4da8da1a}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;transition:all var(--transition);white-space:nowrap}.btn-primary{background:var(--accent-gradient);color:#fff}.btn-primary:hover{box-shadow:0 4px 16px #4da8da59;transform:translateY(-1px)}.btn-secondary{background:#ffffff14;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:#ffffff24;border-color:#fff3}.btn-danger{background:#ef444426;color:var(--error);border:1px solid rgba(239,68,68,.25)}.btn-danger:hover{background:#ef444440}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:#ffffff0f;color:var(--text-secondary);border:1px solid var(--border);font-size:18px;transition:all var(--transition)}.btn-icon:hover{background:#ffffff1f;color:var(--text-primary);border-color:#fff3}.section{margin-top:48px;scroll-margin-top:80px}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.section-icon{font-size:24px}.section-title{font-size:22px;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:14px;color:var(--text-muted);margin-top:2px}.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 0 16px}.hero-avatar{width:96px;height:96px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:700;color:#fff;margin-bottom:16px;overflow:hidden;border:3px solid rgba(255,255,255,.12)}.hero-avatar img{width:100%;height:100%;object-fit:cover}.avatar-upload{display:flex;align-items:center;gap:16px}.avatar-preview{width:80px;height:80px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;color:#fff;overflow:hidden;border:2px solid rgba(255,255,255,.12);flex-shrink:0}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-actions{display:flex;flex-direction:column;gap:8px}.hero-name{font-size:30px;font-weight:800;letter-spacing:1px;margin-bottom:6px}.hero-title{display:inline-block;padding:4px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.2);margin-bottom:8px}.hero-tagline{font-size:15px;color:var(--text-secondary);max-width:560px;line-height:1.7;margin-bottom:4px}.hero-meta{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;margin-bottom:4px}.hero-meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.hero-meta-item .icon{font-size:15px}.hero-highlights{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:16px;margin-bottom:12px}.highlight-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 20px;min-width:160px;flex:1;max-width:220px;text-align:center;transition:all var(--transition)}.highlight-card:hover{background:var(--bg-card-hover);border-color:var(--border-focus);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.highlight-card .highlight-icon{font-size:22px;margin-bottom:6px}.highlight-card .highlight-value{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.highlight-card .highlight-label{font-size:12px;color:var(--text-muted)}.hero-contact-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:4px}.hero-contact-bar .contact-item{padding:8px 14px;font-size:13px}.bio{max-width:700px;margin:0 auto;font-size:15px;color:var(--text-secondary);line-height:1.8;text-align:center}.contacts-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.contact-item{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);font-size:14px;color:var(--text-secondary);transition:all var(--transition);cursor:pointer;-webkit-user-select:none;user-select:none}.contact-item:hover{background:var(--bg-card-hover);border-color:var(--border-focus);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.contact-item .icon{font-size:18px}.contact-item.copyable:after{content:"📋";font-size:12px;opacity:0;transition:opacity var(--transition);margin-left:2px}.contact-item.copyable:hover:after{opacity:.6}.skills-container{display:flex;flex-direction:column;gap:24px}.skill-category-name{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-left:2px}.skills-cloud{display:flex;flex-wrap:wrap;gap:10px}.skill-tag{display:flex;flex-direction:column;gap:6px;padding:10px 16px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);min-width:120px;transition:all var(--transition)}.skill-tag:hover{background:var(--bg-card-hover);border-color:var(--border-focus);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.skill-tag-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.skill-tag-name{font-size:14px;font-weight:500;color:var(--text-primary)}.skill-tag-level{font-size:12px;color:var(--text-muted)}.skill-bar{height:4px;border-radius:2px;background:#ffffff14;overflow:hidden}.skill-bar-fill{height:100%;border-radius:2px;background:var(--accent-gradient);width:0;transition:width 1s ease}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.project-card{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);overflow:hidden;transition:all var(--transition);display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #00000073;border-color:#4da8da4d;background:#ffffff0f}.project-cover{width:100%;height:160px;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fffc;overflow:hidden}.project-cover img{width:100%;height:100%;object-fit:cover}.project-cover.cover-2{background:linear-gradient(135deg,#6366f1,#a855f7)}.project-cover.cover-3{background:linear-gradient(135deg,#06b6d4,#4da8da)}.project-cover.cover-4{background:linear-gradient(135deg,#f59e0b,#ef4444)}.project-body{padding:18px 20px;flex:1;display:flex;flex-direction:column;gap:10px}.project-name{font-size:17px;font-weight:700;color:var(--text-primary)}.project-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-meta{font-size:12px;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:12px}.project-meta-item{display:flex;align-items:center;gap:4px}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.project-tag{padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:500;background:#4da8da1f;color:#7cc4e8}.project-links{display:flex;gap:10px;margin-top:6px}.project-link{font-size:13px;display:inline-flex;align-items:center;gap:4px}.project-link.video-link{color:#f59e0b}.project-link.video-link:hover{color:#fbbf24}.project-stats{display:flex;gap:16px;font-size:12px;color:var(--text-muted)}.project-stat{display:flex;align-items:center;gap:4px}.experiences-list{display:flex;flex-direction:column;gap:20px}.exp-section-title{font-size:15px;font-weight:600;color:var(--text-secondary);margin-bottom:12px;display:flex;align-items:center;gap:8px}.timeline{display:flex;flex-direction:column;gap:16px;padding-left:20px;border-left:2px solid var(--border)}.timeline-item{position:relative;padding-left:20px}.timeline-item:before{content:"";position:absolute;left:-26px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--accent-gradient)}.timeline-title{font-size:15px;font-weight:600;color:var(--text-primary)}.timeline-subtitle{font-size:13px;color:var(--text-secondary)}.timeline-date{font-size:12px;color:var(--text-muted);margin-top:2px}.timeline-desc{font-size:13px;color:var(--text-secondary);margin-top:4px;line-height:1.6}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;opacity:0;visibility:hidden;transition:all .3s ease}.drawer-overlay.open{opacity:1;visibility:visible}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:100vw;background:var(--bg-secondary);border-left:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease;box-shadow:var(--shadow-lg)}.drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-title{font-size:18px;font-weight:700}.drawer-close{width:36px;height:36px;border-radius:var(--radius-sm);background:#ffffff0f;color:var(--text-secondary);border:1px solid var(--border);font-size:18px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.drawer-close:hover{background:#ffffff1f;color:var(--text-primary)}.drawer-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}.drawer-tab{padding:12px 18px;font-size:13px;font-weight:500;color:var(--text-muted);background:none;border-bottom:2px solid transparent;transition:all var(--transition);white-space:nowrap;flex-shrink:0}.drawer-tab:hover{color:var(--text-secondary)}.drawer-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.drawer-body{flex:1;overflow-y:auto;padding:24px}.drawer-body::-webkit-scrollbar{width:4px}.drawer-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.drawer-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;flex-shrink:0}.drawer-footer .btn{flex:1;justify-content:center}.tab-panel{display:none}.tab-panel.active{display:block}.form-group{margin-bottom:18px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid var(--border);color:var(--text-primary);font-size:14px;transition:all var(--transition);outline:none}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #4da8da1a}.form-textarea{resize:vertical;min-height:80px}.form-select{-webkit-appearance:none;-moz-appearance:none;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='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.form-actions{display:flex;gap:8px;margin-top:8px}.editor-list{display:flex;flex-direction:column;gap:16px}.editor-card{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.editor-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.editor-card-title{font-size:14px;font-weight:600;color:var(--text-secondary)}.editor-card-remove{width:28px;height:28px;border-radius:var(--radius-sm);background:#ef44441a;color:var(--error);border:none;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.editor-card-remove:hover{background:#ef444440}.github-sync-area{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.github-repo-list{display:flex;flex-direction:column;gap:10px;margin-top:16px;max-height:360px;overflow-y:auto}.github-repo-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}.github-repo-item label{display:flex;align-items:center;gap:10px;flex:1;cursor:pointer}.github-repo-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}.github-repo-name{font-weight:500;color:var(--text-primary);flex:1}.github-repo-lang,.github-repo-stars{font-size:12px;color:var(--text-muted)}.github-repo-link{font-size:14px;color:var(--text-muted);text-decoration:none;margin-left:auto;transition:color var(--transition)}.github-repo-link:hover{color:var(--accent)}.import-export-area{display:flex;flex-direction:column;gap:16px}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-20px);padding:12px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;z-index:9999;opacity:0;transition:all .3s ease;pointer-events:none;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-lg)}.toast-show{opacity:1;transform:translate(-50%) translateY(0)}.toast-icon{font-size:16px}.toast-success{background:#065f46;color:#a7f3d0;border:1px solid #059669}.toast-error{background:#7f1d1d;color:#fecaca;border:1px solid #dc2626}.toast-warning{background:#78350f;color:#fde68a;border:1px solid #d97706}.toast-info{background:#1e3a5f;color:#bae6fd;border:1px solid #0284c7}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state-icon{font-size:40px;margin-bottom:12px}.empty-state-text{font-size:14px}.footer{text-align:center;padding:40px 0 20px;color:var(--text-muted);font-size:13px;border-top:1px solid var(--border);margin-top:60px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .2s ease}.confirm-overlay.open{opacity:1;visibility:visible}.confirm-dialog{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px;max-width:380px;width:90vw;text-align:center;box-shadow:var(--shadow-lg)}.confirm-title{font-size:17px;font-weight:700;margin-bottom:8px}.confirm-message{font-size:14px;color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.confirm-actions{display:flex;gap:12px;justify-content:center}.confirm-actions .btn{min-width:80px;justify-content:center}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:640px){#app{padding:0 16px 40px}.top-bar{margin:0 -16px;padding-left:16px;padding-right:16px}.top-bar-nav{display:none}.hero-name{font-size:24px}.hero-tagline{font-size:14px}.hero-highlights{gap:10px}.highlight-card{min-width:100px;max-width:none;flex:1 1 100px;padding:10px 14px}.highlight-card .highlight-value{font-size:16px}.section{margin-top:36px}.section-title{font-size:19px}.projects-grid{grid-template-columns:1fr}.contacts-grid{gap:8px}.contact-item{padding:8px 14px;font-size:13px}.drawer{width:100vw}.drawer-tab{padding:10px 14px;font-size:12px}.skill-tag{min-width:100px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .5s ease forwards}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.15s}.stagger>*:nth-child(4){animation-delay:.2s}.stagger>*:nth-child(5){animation-delay:.25s}.stagger>*:nth-child(6){animation-delay:.3s}
