*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 20px}.btn{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-size:16px;padding:10px 20px;text-decoration:none}.btn:hover{background:#0056b3}.btn-danger{background:#dc3545}.btn-danger:hover{background:#c82333}.App{background:linear-gradient(135deg,#f8fafcf2,#f1f5f9e6);display:flex;flex-direction:column;min-height:100vh}@media (prefers-color-scheme:dark){.App{background:linear-gradient(135deg,#0f172af2,#1e293be6)}}.main-content{flex:1 1;overflow:hidden;padding:40px 0;position:relative}.main-content:before{animation:float 20s ease-in-out infinite;background:var(--primary-gradient);height:500px;right:-20%;top:-50%;width:500px}.main-content:after,.main-content:before{border-radius:50%;content:"";opacity:.05;position:absolute;z-index:0}.main-content:after{animation:float 25s ease-in-out infinite reverse;background:var(--secondary-gradient);bottom:-30%;height:400px;left:-15%;width:400px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-20px) rotate(120deg)}66%{transform:translateY(20px) rotate(240deg)}}.post-card-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:32px;position:relative;z-index:1}@media (max-width:768px){.main-content{padding:24px 0}.post-card-grid{gap:24px;grid-template-columns:1fr}}.fade-in{animation:fadeIn .6s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .8s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.separator{background:linear-gradient(90deg,#0000,var(--border-color),#0000);height:1px;margin:40px 0;position:relative}.separator:before{background:var(--light-bg);color:var(--primary-color);content:"✦";font-size:14px;left:50%;padding:0 20px;position:absolute;top:50%;transform:translate(-50%,-50%)}.header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffffe6;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);left:0;position:fixed;right:0;top:0;transition:all var(--transition-normal);z-index:1000}.header.scrolled{background:#fffffffa;box-shadow:var(--shadow-lg);padding:8px 0}@media (prefers-color-scheme:dark){.header{background:#0f172ae6}.header.scrolled{background:#0f172afa}}.header-content{align-items:center;display:flex;justify-content:space-between;padding:20px 0;transition:padding var(--transition-normal)}.header.scrolled .header-content{padding:12px 0}.logo a{align-items:center;background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;color:#0000;display:flex;font-size:28px;font-weight:800;gap:10px;padding:8px 0;position:relative;text-decoration:none}.logo a:after{background:var(--primary-gradient);bottom:0;content:"";height:2px;left:0;position:absolute;transition:width var(--transition-normal);width:0}.logo a:hover:after{width:100%}.nav{gap:12px}.nav,.nav-link{align-items:center;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);font-size:15px;font-weight:500;gap:8px;padding:10px 20px;position:relative;text-decoration:none;transition:all var(--transition-normal)}.nav-link:before{background:var(--primary-gradient);border-radius:inherit;content:"";inset:0;opacity:0;position:absolute;transition:opacity var(--transition-normal);z-index:-1}.nav-link:hover{color:#fff;transform:translateY(-2px)}.nav-link:hover:before{opacity:1}.nav-link.active{background:var(--primary-gradient);box-shadow:0 4px 15px #667eea66;color:#fff}@media (max-width:768px){.nav{gap:8px}.nav-link{font-size:14px;padding:8px 16px}.logo a{font-size:24px}}.mobile-menu-btn{background:none;border:none;cursor:pointer;display:none;height:32px;position:relative;width:32px;z-index:1001}.mobile-menu-btn span{background:var(--primary-color);border-radius:2px;display:block;height:2px;margin:6px 0;transition:all var(--transition-normal);width:100%}.mobile-menu-btn.active span:first-child{transform:rotate(45deg) translate(6px,6px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}@media (max-width:640px){.mobile-menu-btn{display:block}.nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--card-bg);box-shadow:var(--shadow-xl);flex-direction:column;height:100vh;left:-100%;padding:80px 24px 24px;position:fixed;top:0;transition:left var(--transition-normal);width:80%}.nav.active{left:0}.nav-link{font-size:16px;justify-content:center;width:100%}}.footer{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px 0;position:relative;text-align:center}@media (prefers-color-scheme:dark){.footer{background:linear-gradient(135deg,#1e293b,#0f172a)}}.footer-container{flex-direction:column;gap:32px;margin:0 auto;max-width:1200px;padding:0 24px}.copyright-section,.footer-container{align-items:center;display:flex;justify-content:center}.copyright-section{gap:12px}.copyright-text{color:#fffffff2;font-size:16px;font-weight:500;letter-spacing:.5px}.social-links{display:flex;flex-wrap:wrap;gap:32px;justify-content:center}.social-link{align-items:center;color:inherit;display:flex;flex-direction:column;gap:8px;text-decoration:none;transition:all .3s ease}.social-icon{color:#ffffffe6;font-size:28px;transition:all .3s ease}.social-text{color:#fffc;font-size:12px;font-weight:500;letter-spacing:.5px}.social-link:hover .social-icon{color:#fff;transform:translateY(-4px)}.social-link:hover .social-text{color:#fff}@media (max-width:768px){.footer{padding:32px 0}.footer-container{gap:24px;padding:0 16px}.social-links{gap:24px}.social-icon{font-size:24px}.copyright-text{font-size:15px}}@media (max-width:480px){.footer-container,.social-links{gap:20px}.social-icon{font-size:22px}.copyright-text{font-size:14px}}.post-card{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;overflow:hidden;position:relative;transition:transform .3s,box-shadow .3s}.post-actions{display:flex;gap:8px;opacity:0;position:absolute;right:10px;top:10px;transition:opacity .3s;z-index:10}.post-card:hover .post-actions{opacity:1}.delete-btn,.edit-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:12px;gap:4px;padding:6px 12px;transition:all .3s}.delete-btn{background:#ff4d4f;color:#fff}.delete-btn:hover{background:#ff7875;transform:translateY(-1px)}.delete-btn:disabled{background:#ffccc7;cursor:not-allowed;transform:none}.edit-btn{background:#1890ff}.edit-btn:hover{background:#40a9ff;transform:translateY(-1px)}.edit-btn a{align-items:center;color:#fff;display:flex;gap:4px;text-decoration:none}.home{padding:40px 0}.hero-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;margin-bottom:40px;padding:60px 0;text-align:center}.hero-section h1{font-size:48px;margin-bottom:20px;text-shadow:2px 2px 4px #0003}.hero-subtitle{font-size:20px;margin:0 auto;max-width:800px;opacity:.9}.featured-posts h2{color:#333;font-size:32px;margin-bottom:30px}.cta-section{background:#f8f9fa;border-radius:10px;margin-top:60px;padding:60px 0;text-align:center}.cta-section h2{color:#333;margin-bottom:15px}.cta-section p{color:#666;font-size:18px;margin-bottom:25px}.posts-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.author-controls{align-items:flex-end;display:flex;flex-direction:column;gap:5px}.author-hint{background:#f6ffed;border:1px solid #b7eb8f;border-radius:4px;color:#52c41a;font-size:14px;padding:4px 12px}.delete-hint{color:#666;font-size:12px;font-style:italic}.ant-popconfirm-message-title{color:#ff4d4f}.ant-popconfirm-buttons .ant-btn-dangerous{background:#ff4d4f;border-color:#ff4d4f}.ant-popconfirm-buttons .ant-btn-dangerous:hover{background:#ff7875;border-color:#ff7875}.user-profile-edit{background-color:#f8f9fa;border-radius:12px;box-shadow:0 4px 20px #00000014;margin:0 auto;max-width:800px;padding:30px}.user-profile-edit h2{color:#333;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.form-section{margin-bottom:25px}.form-section label{color:#444;display:block;font-size:16px;font-weight:600;margin-bottom:8px}.form-section input,.form-section textarea{background-color:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:15px;padding:12px 15px;transition:all .3s ease;width:100%}.form-section input:focus,.form-section textarea:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a;outline:none}.form-section input:disabled,.form-section textarea:disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed}.form-section textarea{font-family:inherit;min-height:80px;resize:vertical}.avatar-section{align-items:center;display:flex;gap:20px;margin-bottom:10px}.avatar-preview{border:3px solid #e1e5e9;border-radius:50%;flex-shrink:0;height:100px;overflow:hidden;width:100px}.avatar-preview img{height:100%;object-fit:cover;width:100%}.avatar-section input{flex-grow:1}.hint{color:#888;font-size:13px;margin-top:5px}.tech-stack-container{background-color:#fff;border:2px solid #e1e5e9;border-radius:8px;padding:20px}.tech-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.tech-tag{align-items:center;background-color:#e3f2fd;border-radius:20px;box-shadow:0 2px 4px #0000000d;color:#1976d2;display:inline-flex;font-size:14px;padding:8px 15px}.remove-tech{align-items:center;background:none;border:none;border-radius:50%;color:#f44336;cursor:pointer;display:flex;font-size:18px;height:20px;justify-content:center;margin-left:8px;padding:0;width:20px}.remove-tech:hover{background-color:#f443361a}.no-tech{color:#999;font-style:italic;margin-bottom:20px}.tech-input-group{display:flex;gap:10px}.tech-input-group input{border:2px solid #4a90e2;border-radius:8px;flex-grow:1;padding:10px 15px}.add-tech-btn{background-color:#4a90e2;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:background-color .3s}.add-tech-btn:hover{background-color:#357ae8}.action-buttons{border-top:1px solid #e1e5e9;display:flex;gap:20px;justify-content:center;margin-top:40px;padding-top:30px}.action-buttons button{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;min-width:140px;padding:12px 30px;transition:all .3s ease}.edit-btn{background-color:#4caf50;color:#fff}.edit-btn:hover{background-color:#45a049;transform:translateY(-2px)}.save-btn{background-color:#2196f3;color:#fff}.save-btn:hover{background-color:#0b7dda;transform:translateY(-2px)}.cancel-btn{background-color:#f5f5f5;border:2px solid #ddd!important;color:#666}.cancel-btn:hover{background-color:#e0e0e0}.reset-btn{background-color:#ff9800;color:#fff}.reset-btn:hover{background-color:#f57c00}@media (max-width:768px){.user-profile-edit{margin:10px;padding:20px}.avatar-section{align-items:flex-start;flex-direction:column}.avatar-preview{align-self:center}.action-buttons{flex-direction:column;gap:15px}.action-buttons button{width:100%}}.archive-container{padding:40px 0}.archive-container h1{color:#333;margin-bottom:30px}.archive-content{grid-gap:40px;display:grid;gap:40px;grid-template-columns:1fr 300px}.archive-list h2{color:#444;margin-bottom:20px}.archive-year{margin-bottom:30px}.archive-year h3{border-bottom:2px solid #007bff;color:#333;font-size:24px;margin-bottom:15px;padding-bottom:10px}.archive-month{margin-bottom:20px;padding-left:20px}.archive-month h4{color:#555;font-size:18px;margin-bottom:10px}.archive-month ul{list-style:none}.archive-month li{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px 0}.archive-month a{color:#333;flex:1 1;text-decoration:none}.archive-month a:hover{color:#007bff}.post-date{color:#888;font-size:14px}.archive-sidebar{margin-top:50px}.sidebar-widget{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:20px}.sidebar-widget h3{color:#333;margin-bottom:15px}.sidebar-widget ul{list-style:none}.sidebar-widget li{margin-bottom:8px}.sidebar-widget a{color:#555;text-decoration:none}.sidebar-widget a:hover{color:#007bff}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{background:#e9ecef;border-radius:20px;color:#495057;cursor:pointer;font-size:14px;padding:6px 12px}.tag:hover{background:#dee2e6}.post-detail{padding:40px 0}.post-content{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000000d;padding:40px}.post-header{margin-bottom:30px}.post-header .post-meta{color:#666;display:flex;font-size:14px;gap:20px;margin-bottom:15px}.post-category{color:#007bff;font-weight:500}.post-title{color:#333;font-size:36px;line-height:1.3;margin-bottom:20px}.post-author{gap:15px}.author-avatar,.post-author{align-items:center;display:flex}.author-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:20px;font-weight:700;height:50px;justify-content:center;width:50px}.author-name{color:#333;font-weight:500}.post-featured-image{border-radius:8px;margin:30px 0;overflow:hidden}.post-featured-image img{border-radius:8px;height:auto;width:100%}.post-body{color:#444;font-size:18px;line-height:1.8}.post-body p{margin-bottom:20px}.post-tags{border-top:1px solid #eee;margin-top:40px;padding-top:20px}.post-footer{border-top:2px solid #eee;margin-top:40px;padding-top:30px}.social-share h3{color:#333;margin-bottom:15px}.share-buttons{display:flex;gap:10px}.share-btn{border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px}.share-btn.weibo{background:#e6162d}.share-btn.wechat{background:#07c160}.share-btn.qq{background:#12b7f5}.related-posts{margin-top:60px}.related-posts h2{color:#333;margin-bottom:30px}.related-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.related-post{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000000d;padding:25px}.related-post h3{margin-bottom:15px}.related-post h3 a{color:#333;font-size:20px;text-decoration:none}.related-post h3 a:hover{color:#007bff}.related-post p{color:#666;line-height:1.6}.loading,.not-found{color:#666;font-size:20px;padding:100px 0;text-align:center}.post-detail-actions{border-bottom:1px solid #f0f0f0;display:flex;gap:15px;justify-content:flex-end;margin-bottom:30px;padding-bottom:20px}.post-detail-actions .ant-btn{align-items:center;border-radius:6px;display:flex;gap:8px;height:auto;padding:8px 20px}.post-detail-actions .ant-btn-danger{background:#ff4d4f;border-color:#ff4d4f}.post-detail-actions .ant-btn-danger:hover{background:#ff7875;border-color:#ff7875}.post-detail-actions .ant-btn-default{border-color:#1890ff;color:#1890ff}.post-detail-actions .ant-btn-default:hover{background:#1890ff0a;border-color:#40a9ff;color:#40a9ff}.auth-container{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;justify-content:center;min-height:70vh;padding:40px 20px}.auth-form{background:#fff;border:1px solid #0000000f;border-radius:12px;box-shadow:0 8px 32px #00000014;max-width:400px;padding:40px;width:100%}.auth-form h2{color:#333;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.form-group{margin-bottom:24px}.form-group label{color:#555;display:block;font-size:15px;font-weight:500;margin-bottom:8px}.form-group input{background:#fafafa;border:1.5px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group input:hover{background:#fff;border-color:#1890ff}.form-group input:focus{box-shadow:0 0 0 3px #1890ff1a;outline:none}.btn-primary{background:linear-gradient(135deg,#1890ff,#096dd9);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;margin-top:10px;padding:14px;transition:all .3s ease;width:100%}.btn-primary:hover{background:linear-gradient(135deg,#40a9ff,#1890ff);box-shadow:0 6px 16px #1890ff4d;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.toggle-form{color:#666;font-size:15px;line-height:1.5;margin-top:24px;text-align:center}.toggle-btn{background:none;border:none;color:#1890ff;cursor:pointer;font-size:15px;font-weight:500;margin-left:5px;padding:0;text-decoration:underline;transition:color .3s}.toggle-btn:hover{color:#0050b3}.back-home{border-top:1px solid #f0f0f0;margin-top:20px;padding-top:20px;text-align:center}.back-home a{color:#666;font-size:14px;text-decoration:none;transition:color .3s}.back-home a:hover{color:#1890ff}@media (max-width:768px){.auth-container{padding:20px 15px}.auth-form{padding:30px 25px}.auth-form h2{font-size:24px;margin-bottom:25px}}@media (max-width:480px){.auth-form{padding:25px 20px}.auth-form h2{font-size:22px}.form-group input{font-size:15px;padding:10px 14px}.btn-primary{font-size:15px;padding:12px}}@media (prefers-color-scheme:dark){.auth-container{background:linear-gradient(135deg,#1a1a1a,#2d2d2d)}.auth-form{background:#2a2a2a;border-color:#404040;box-shadow:0 8px 32px #0003}.auth-form h2{color:#f0f0f0}.form-group label{color:#bfbfbf}.form-group input{background:#333;border-color:#555;color:#f0f0f0}.form-group input:focus,.form-group input:hover{background:#3a3a3a;border-color:#40a9ff}.form-group input:focus{box-shadow:0 0 0 3px #40a9ff1a}.form-group input::placeholder{color:#888}.toggle-form{color:#bfbfbf}.toggle-btn{color:#40a9ff}.toggle-btn:hover{color:#69c0ff}.back-home{border-top-color:#404040}.back-home a{color:#bfbfbf}.back-home a:hover{color:#40a9ff}}.blog-layout{min-height:100vh}.notfound-content{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 134px);padding:40px 20px}.ant-result{padding:0!important}.ant-result-title{color:#1890ff!important;font-size:120px!important;font-weight:700!important;margin-bottom:20px!important;text-shadow:2px 2px 4px #0000001a}.ant-result-subtitle{color:#666!important;font-size:24px!important;line-height:1.6;margin-bottom:40px!important;max-width:600px}.notfound-actions{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:30px}.notfound-actions .ant-btn{border-radius:8px;font-size:16px;height:48px;padding:0 40px;transition:all .3s ease}.notfound-actions .ant-btn-primary{background:linear-gradient(135deg,#1890ff,#0050b3);border:none;box-shadow:0 4px 12px #1890ff4d}.notfound-actions .ant-btn-primary:hover{box-shadow:0 6px 16px #1890ff66;transform:translateY(-2px)}.notfound-actions .ant-btn:not(.ant-btn-primary){background:#0000;border:2px solid #1890ff;color:#1890ff}.notfound-actions .ant-btn:not(.ant-btn-primary):hover{background:#1890ff1a;transform:translateY(-2px)}.notfound-suggestions{animation:fadeInUp .6s ease .3s both;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000014;margin-top:60px;max-width:600px;padding:30px;width:100%}.notfound-suggestions h3{border-bottom:2px solid #f0f0f0;color:#333;font-size:20px;font-weight:600;margin-bottom:20px;padding-bottom:15px}.notfound-suggestions ul{list-style:none;margin:0;padding:0}.notfound-suggestions li{align-items:center;border-bottom:1px solid #f5f5f5;color:#666;display:flex;font-size:16px;padding:12px 0}.notfound-suggestions li:last-child{border-bottom:none}.notfound-suggestions li:before{color:#1890ff;content:"•";font-size:20px;margin-right:12px}.notfound-suggestions a{color:#1890ff;font-weight:500;margin-left:5px;text-decoration:none;transition:color .3s}.notfound-suggestions a:hover{color:#0050b3;text-decoration:underline}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.notfound-content{min-height:calc(100vh - 120px);padding:20px 15px}.ant-result-title{font-size:80px!important}.ant-result-subtitle{font-size:18px!important}.notfound-actions{flex-direction:column;max-width:300px;width:100%}.notfound-actions .ant-btn{margin-bottom:10px;width:100%}.notfound-suggestions{margin-top:40px;padding:20px}.notfound-suggestions li{font-size:15px}}@media (max-width:480px){.ant-result-title{font-size:60px!important}.ant-result-subtitle{font-size:16px!important}.notfound-suggestions h3{font-size:18px}}@media (prefers-color-scheme:dark){.notfound-content{background:linear-gradient(135deg,#1a1a1a,#2d3748)}.ant-result-subtitle{color:#d9d9d9!important}.notfound-suggestions{background:#2a2a2a;box-shadow:0 8px 24px #0003}.notfound-suggestions h3{border-bottom-color:#404040;color:#fff}.notfound-suggestions li{border-bottom-color:#404040;color:#bfbfbf}.notfound-suggestions a,.notfound-suggestions li:before{color:#40a9ff}.notfound-suggestions a:hover{color:#69c0ff}}
/*# sourceMappingURL=main.ee213448.css.map*/