*,body{margin:0}*{box-sizing:border-box;padding:0}:root{--background-color:#f8f9fa;--surface-color:#fff;--text-color:#333;--text-secondary:#666;--border-color:#e1e4e8;--primary-color:#007bff;--primary-hover:#0056b3;--accent-color:#6c757d;--code-background:#f5f5f5;--scrollbar-track:#f1f1f1;--scrollbar-thumb:#c1c1c1;--scrollbar-thumb-hover:#a8a8a8}[data-theme=dark]{--background-color:#1a1a1a;--surface-color:#2d2d2d;--text-color:#fff;--text-secondary:#b0b0b0;--border-color:#444;--primary-color:#4dabf7;--primary-hover:#339af0;--accent-color:#adb5bd;--code-background:#3d3d3d;--scrollbar-track:#2d2d2d;--scrollbar-thumb:#555;--scrollbar-thumb-hover:#666}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--background-color);color:#333;color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;transition:background-color .3s ease,color .3s ease}.App{display:flex;flex-direction:column;min-height:100vh}.App,.main-content{background-color:#f8f9fa;background-color:var(--background-color);transition:background-color .3s ease}.main-content{flex:1 1;width:100%}a{color:#007bff;color:var(--primary-color);text-decoration:none;transition:color .3s ease}a:hover{color:#0056b3;color:var(--primary-hover)}h1,h2,h3,h4,h5,h6{color:#333;color:var(--text-color);font-weight:600;line-height:1.3;transition:color .3s ease}ol,ul{list-style:none}img{display:block;height:auto;max-width:100%}code{background-color:#f5f5f5;background-color:var(--code-background);border-radius:4px;color:#333;color:var(--text-color);font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.9em;padding:2px 6px;transition:background-color .3s ease,color .3s ease}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1;background:var(--scrollbar-track)}::-webkit-scrollbar-thumb,::-webkit-scrollbar-track{border-radius:4px;-webkit-transition:background .3s ease;transition:background .3s ease}::-webkit-scrollbar-thumb{background:#c1c1c1;background:var(--scrollbar-thumb)}::-webkit-scrollbar-thumb:hover{background:#a8a8a8;background:var(--scrollbar-thumb-hover);-webkit-transition:background .3s ease;transition:background .3s ease}.card{background-color:#fff;background-color:var(--surface-color);border:1px solid #e1e4e8;border:1px solid var(--border-color);border-radius:8px;transition:background-color .3s ease,border-color .3s ease}.btn{background-color:#007bff;background-color:var(--primary-color);border-radius:4px;color:#fff;padding:8px 16px;transition:background-color .3s ease}.btn:hover{background-color:#0056b3;background-color:var(--primary-hover)}.form-input{background-color:var(--surface-color);border:1px solid #e1e4e8;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);padding:8px 12px;transition:background-color .3s ease,border-color .3s ease,color .3s ease}.form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #007bff40}.header{background-color:var(--primary-color);box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:0;transition:background-color .3s ease;z-index:1000}.header-container{align-items:center;display:flex;height:60px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.logo{font-size:24px;font-weight:700}.logo-link{color:#fff;text-decoration:none;transition:color .3s ease}.logo-link:hover{color:#fffc}.nav{align-items:center;display:flex;gap:10px}.nav-link{border-radius:4px;color:#fffc;font-size:16px;font-weight:500;padding:8px 12px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background-color:#fff3;color:#fff}.nav-link.active{background-color:#ffffff4d;color:#fff;font-weight:600}.theme-toggle-btn{align-items:center;background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:20px;justify-content:center;padding:8px 12px;transition:all .3s ease}.theme-toggle-btn:hover{background-color:#fff3;transform:scale(1.1)}.user-dropdown{position:relative}.user-dropdown-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#fffc;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:8px;padding:8px 12px;transition:all .3s ease}.user-dropdown:hover .user-dropdown-menu{opacity:1;transform:translateY(0);visibility:visible}.user-dropdown:hover .user-dropdown-toggle{background-color:#fff3;color:#fff}.user-avatar{border:2px solid #ffffff4d;border-radius:50%;height:32px;object-fit:cover;transition:all .3s ease;width:32px}.user-dropdown:hover .user-avatar{border-color:#fff}.user-name{white-space:nowrap}.user-dropdown-menu{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:4px;min-width:240px;opacity:0;position:absolute;right:0;top:100%;transform:translateY(-5px);transition:all .2s ease,background-color .3s ease,border-color .3s ease;visibility:hidden;z-index:1001}.user-dropdown-info{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:12px;padding:16px;transition:border-color .3s ease}.user-dropdown-avatar{border:2px solid var(--border-color);border-radius:50%;height:48px;overflow:hidden;transition:border-color .3s ease;width:48px}.user-dropdown-avatar img{height:100%;object-fit:cover;width:100%}.user-dropdown-name{color:var(--text-color);font-size:16px;font-weight:600;margin-bottom:4px;transition:color .3s ease}.user-dropdown-email{color:var(--text-secondary);font-size:14px;transition:color .3s ease}.user-dropdown-divider{background-color:var(--border-color);height:1px;margin:0;transition:background-color .3s ease}.user-dropdown-item{background:none;border:none;color:var(--text-color);cursor:pointer;display:block;font-size:14px;padding:12px 16px;text-align:left;transition:all .2s ease,color .3s ease,background-color .3s ease;width:100%}.user-dropdown-item:hover{background-color:#007bff1a;color:var(--primary-color)}.user-dropdown-item-logout{color:#dc3545}.user-dropdown-item-logout:hover{background-color:#dc35451a;color:#dc3545}@media (max-width:768px){.header-container{padding:0 15px}.logo{font-size:20px}.nav{gap:8px}.nav-link{font-size:14px;padding:6px 10px}.theme-toggle-btn{font-size:18px;padding:6px 10px}.user-dropdown-toggle{font-size:14px;padding:6px 10px}.user-avatar{height:28px;width:28px}.user-dropdown-menu{min-width:200px;right:-10px}.user-dropdown-info{gap:8px;padding:12px}.user-dropdown-avatar{height:40px;width:40px}.user-dropdown-name{font-size:14px}.user-dropdown-email{font-size:12px}.user-dropdown-item{font-size:13px;padding:10px 12px}}.footer{background-color:#0f111a;border-top:1px solid #e9ecef;padding:2rem 0}.footer-container{margin:0 auto;max-width:1200px;padding:0 1rem}.footer-content{display:flex;flex-wrap:wrap;justify-content:space-around;margin-bottom:2rem}.footer-bottom{align-items:center;border-top:1px solid #e9ecef;display:flex;flex-direction:column;gap:1rem;padding-top:1rem;text-align:center}.footer-copyright{color:#6c757d;font-size:.9rem;margin:0}.footer-social{align-items:center;display:flex;justify-content:center}.footer-icon{color:#6c757d;cursor:pointer;font-size:1.2rem;transition:color .3s ease}.footer-icon:hover{color:#007bff}[data-theme=dark] .footer{background-color:var(--surface-color);border-top-color:var(--border-color)}[data-theme=dark] .footer-copyright,[data-theme=dark] .footer-icon{color:var(--text-secondary)}[data-theme=dark] .footer-icon:hover{color:var(--primary-color)}@media (max-width:768px){.footer-content{align-items:center;flex-direction:column}}.home-page{background-color:var(--background-color);min-height:calc(100vh - 60px);padding:40px 0;transition:background-color .3s ease}.home-container{margin:0 auto;max-width:1200px;padding:0 20px}.home-title{color:var(--text-color);font-size:32px;font-weight:700;margin-bottom:32px;text-align:center;transition:color .3s ease}.posts-list{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}@media (max-width:1200px){.home-container{max-width:960px}}@media (max-width:992px){.home-container{max-width:720px}.posts-list{gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:768px){.home-page{padding:24px 0}.home-container{max-width:100%;padding:0 15px}.home-title{font-size:28px;margin-bottom:24px}.posts-list{gap:16px;grid-template-columns:1fr}}@media (max-width:576px){.home-title{font-size:24px;margin-bottom:20px}}.post-detail-page{background-color:var(--background-color);min-height:calc(100vh - 60px);padding:40px 0;transition:background-color .3s ease}.post-detail-container{margin:0 auto;max-width:800px;padding:0 20px}.post-detail{background-color:var(--surface-color);border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:32px;transition:background-color .3s ease}.post-detail-header{margin-bottom:32px}.post-detail-title{color:var(--text-color);font-size:36px;font-weight:700;line-height:1.3;margin:0 0 16px;transition:color .3s ease}.post-detail-meta{color:var(--text-secondary);display:flex;font-size:14px;gap:20px;margin-bottom:16px;transition:color .3s ease}.post-detail-author,.post-detail-category,.post-detail-date{align-items:center;display:flex}.post-detail-category{background-color:#007bff1a;border-radius:16px;color:var(--primary-color);font-size:12px;font-weight:500;padding:4px 12px;transition:background-color .3s ease,color .3s ease}.post-detail-tags{display:flex;flex-wrap:wrap;gap:12px}.post-detail-tag{background-color:var(--code-background);border-radius:20px;color:var(--text-secondary);font-size:13px;padding:6px 14px;transition:all .3s ease,background-color .3s ease,color .3s ease}.post-detail-tag:hover{background-color:var(--border-color);color:var(--text-color)}.post-detail-content{color:var(--text-color);line-height:1.8;margin-bottom:32px;transition:color .3s ease}.post-detail-paragraph{margin:0 0 24px;text-align:justify}.post-detail-paragraph:contains("```"){background-color:var(--code-background);border-radius:6px;color:var(--text-color);font-family:Courier New,Courier,monospace;overflow-x:auto;padding:16px;transition:background-color .3s ease,color .3s ease;white-space:pre-wrap}.post-detail-footer{border-top:1px solid var(--border-color);margin-top:32px;padding-top:24px;transition:border-color .3s ease}.post-detail-stats{color:var(--text-secondary);display:flex;font-size:16px;gap:24px;margin-bottom:16px;transition:color .3s ease}.post-detail-stat{align-items:center;display:flex}.post-detail-actions{text-align:center}.back-link{background-color:var(--primary-color);border-radius:6px;color:#fff;display:inline-block;font-weight:500;padding:12px 24px;text-decoration:none;transition:all .3s ease,background-color .3s ease}.back-link:hover{background-color:var(--primary-hover);box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}@media (max-width:768px){.post-detail-page{padding:24px 0}.post-detail-container{padding:0 15px}.post-detail{padding:24px}.post-detail-title{font-size:28px}.post-detail-meta{align-items:flex-start;flex-direction:column;gap:8px}.post-detail-content{line-height:1.6}.post-detail-paragraph{margin-bottom:20px}}@media (max-width:576px){.post-detail-title{font-size:24px}.post-detail{padding:20px}.back-link{font-size:14px;padding:10px 20px}}.archive-page{min-height:calc(100vh - 140px);padding:2rem 0}.archive-container{margin:0 auto;max-width:1200px;padding:0 1rem}.archive-title{color:#1890ff;margin-bottom:2rem;text-align:center}.archive-subtitle{margin:2rem 0 1rem}.archive-stats,.chart-card{margin-bottom:2rem}.archive-content{display:flex;flex-direction:column;gap:1.5rem}.year-card{box-shadow:0 2px 8px #0000001a}.month-group,.year-card{margin-bottom:1.5rem}.month-title{border-left:4px solid #1890ff;color:#2c3e50;margin-bottom:1rem;padding-left:1rem}.timeline-content{padding:.5rem 0}.timeline-content .post-title{color:#333;font-size:1.1rem;font-weight:600;text-decoration:none;transition:color .3s}.timeline-content .post-title:hover{color:#1890ff}.timeline-content .post-meta{color:#666;font-size:.9rem;margin-top:.3rem}.archive-summary{background-color:#f5f5f5;border-radius:8px;margin-top:2rem;padding:1rem;text-align:center}@media (max-width:768px){.archive-container{padding:0 .5rem}.archive-title{font-size:1.8rem}.timeline-content .post-title{font-size:1rem}.month-title{font-size:1.2rem}}@media (max-width:480px){.archive-page{padding:1rem 0}.archive-stats .ant-card,.chart-card,.year-card{margin-bottom:1rem}}.about-page{background-color:#f8f9fa;min-height:calc(100vh - 60px);padding:40px 0}.about-container{margin:0 auto;max-width:900px;padding:0 20px}.about-title{color:#333;font-size:32px;font-weight:700;margin-bottom:40px;text-align:center}.about-content{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:32px}.about-profile{align-items:center;border-bottom:1px solid #eee;display:flex;gap:24px;margin-bottom:40px;padding-bottom:24px}.about-avatar{border:4px solid #e3f2fd;border-radius:50%;height:120px;overflow:hidden;width:120px}.avatar-img{height:100%;object-fit:cover;width:100%}.about-info{flex:1 1}.about-name{color:#333;font-size:28px;font-weight:700;margin:0 0 8px}.about-bio{color:#666;font-size:16px;margin:0}.about-section{margin-bottom:32px}.about-section-title{color:#333;font-size:24px;font-weight:700;margin:0 0 16px}.about-section-content{color:#555;line-height:1.7}.about-section-content p{margin:0 0 16px}.about-section-content p:last-child{margin-bottom:0}.about-skills{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.skill-category{background-color:#fafafa;border-radius:6px;padding:20px}.skill-category-title{color:#333;font-size:18px;font-weight:600;margin:0 0 16px}.skill-tags{display:flex;flex-wrap:wrap;gap:10px}.skill-tag{background-color:#e3f2fd;border-radius:20px;color:#007bff;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s ease}.skill-tag:hover{background-color:#bbdefb;transform:translateY(-2px)}.about-contact{color:#555;display:flex;flex-direction:column;gap:16px}.contact-item{align-items:center;display:flex;gap:12px}.contact-label{color:#333;font-weight:600;min-width:80px}.contact-value{flex:1 1}.contact-link{color:#007bff;text-decoration:none;transition:color .3s ease}.contact-link:hover{color:#0056b3;text-decoration:underline}@media (max-width:768px){.about-page{padding:24px 0}.about-container{padding:0 15px}.about-title{font-size:28px;margin-bottom:32px}.about-content{padding:24px}.about-profile{flex-direction:column;gap:16px;margin-bottom:32px;text-align:center}.about-name{font-size:24px}.about-section-title{font-size:20px}.about-skills{gap:16px;grid-template-columns:1fr}.contact-item{align-items:flex-start;flex-direction:column;gap:8px}.contact-label{min-width:auto}}@media (max-width:576px){.about-title{font-size:24px}.about-content{padding:20px}.about-avatar{height:100px;width:100px}}.write-post-page{background-color:#f8f9fa;min-height:calc(100vh - 60px);padding:40px 0}.write-post-container{margin:0 auto;max-width:800px;padding:0 20px}.write-post-title{color:#333;font-size:32px;font-weight:700;margin-bottom:40px;text-align:center}.write-post-form{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:32px}.form-group,.form-row{margin-bottom:24px}.form-row{display:flex;gap:16px}.form-group-half{flex:1 1}.form-input,.form-select,.form-textarea{background-color:#fff;border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:all .3s ease;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.form-textarea{font-family:inherit;line-height:1.6;min-height:300px;resize:vertical}.form-hint{color:#666;font-size:13px;margin-bottom:0;margin-top:8px}.form-actions{border-top:1px solid #eee;gap:16px;justify-content:flex-end;margin-top:32px;padding-top:24px}.btn-secondary{background-color:#f0f0f0;color:#333}.btn-secondary:hover{background-color:#e0e0e0;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}@media (max-width:768px){.write-post-page{padding:24px 0}.write-post-container{padding:0 15px}.write-post-title{font-size:28px;margin-bottom:32px}.write-post-form{padding:24px}.form-row{flex-direction:column;gap:0}.form-group-half{margin-bottom:24px}.form-textarea{min-height:250px}.form-actions{flex-direction:column}.btn{width:100%}}@media (max-width:576px){.write-post-title{font-size:24px}.write-post-form{padding:20px}.form-input,.form-select,.form-textarea{font-size:15px;padding:10px 14px}.btn{font-size:15px;padding:10px 20px}}.auth-page{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;min-height:calc(100vh - 60px);padding:20px}.auth-container{max-width:500px;width:100%}.auth-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 12px #0000001a;padding:32px}.auth-title{color:#333;font-size:28px;font-weight:700;margin:0 0 24px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{margin-bottom:0}.form-label{color:#333;display:block;font-size:16px;font-weight:600;margin-bottom:8px}.form-input{background-color:#fff;border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:all .3s ease;width:100%}.form-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:16px;font-weight:500;justify-content:center;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn-primary{background-color:#007bff;color:#fff;margin-top:8px;width:100%}.btn-primary:hover{background-color:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.auth-toggle{color:#666;font-size:14px;margin-top:20px;text-align:center}.auth-toggle-btn{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;font-weight:500;padding:0;transition:color .3s ease}.auth-toggle-btn:hover{color:#0056b3;text-decoration:underline}@media (max-width:768px){.auth-page{padding:15px}.auth-card{padding:24px}.auth-title{font-size:24px;margin-bottom:20px}.auth-form{gap:16px}.form-input{font-size:15px;padding:10px 14px}.btn{font-size:15px;padding:10px 20px}}@media (max-width:576px){.auth-card{padding:20px}.auth-title{font-size:22px}}.user-info-page{min-height:calc(100vh - 140px);padding:2rem 0}.user-info-container{margin:0 auto;max-width:600px;padding:0 1rem}.user-info-card{border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.avatar-section{align-items:center;display:flex;justify-content:center;margin-bottom:1rem}.user-avatar-large{border:4px solid #f0f0f0;box-shadow:0 2px 8px #00000026}.user-info-section{margin-top:1rem}.info-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;padding:.5rem 0}.info-item:last-child{border-bottom:none}.info-item .ant-typography{margin:0}.info-item .ant-typography:first-child{font-weight:600;min-width:80px}.form-actions{gap:1rem}.form-actions,.user-actions{display:flex;justify-content:center;margin-top:1rem}@media (max-width:768px){.user-info-container{max-width:100%}.user-avatar-large{size:96px}}.not-found-page{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;min-height:calc(100vh - 60px);padding:20px}.not-found-container{max-width:600px;width:100%}.not-found-content{background-color:#fff;border-radius:8px;box-shadow:0 2px 12px #0000001a;padding:48px 32px;text-align:center}.not-found-title{color:#007bff;font-size:120px;font-weight:700;line-height:1;margin:0 0 16px}.not-found-subtitle{color:#333;font-size:32px;font-weight:700;margin:0 0 16px}.not-found-message{color:#666;font-size:16px;line-height:1.6;margin:0 0 32px}.not-found-link{background-color:#007bff;border-radius:6px;color:#fff;display:inline-block;font-size:16px;font-weight:500;padding:12px 24px;text-decoration:none;transition:all .3s ease}.not-found-link:hover{background-color:#0056b3;box-shadow:0 4px 12px #007bff4d;color:#fff;transform:translateY(-2px)}@media (max-width:768px){.not-found-content{padding:40px 24px}.not-found-title{font-size:100px}.not-found-subtitle{font-size:28px}.not-found-message{font-size:15px;margin-bottom:24px}}@media (max-width:576px){.not-found-content{padding:32px 20px}.not-found-title{font-size:80px}.not-found-subtitle{font-size:24px}.not-found-link{font-size:15px;padding:10px 20px}}
/*# sourceMappingURL=main.f3ebc700.css.map*/