@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Fira+Code&display=swap);.admin-login{align-items:center;background:#f7fafc;background:var(--bg-body,#f7fafc);display:flex;justify-content:center;margin-bottom:-3rem;margin-top:-3rem;min-height:100vh;overflow:hidden;padding:20px;position:relative}.admin-login:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#667eea1a 0,#f7fafc00 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%;z-index:0}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #ffffff80;border-radius:20px;box-shadow:var(--shadow-lg);max-width:400px;padding:40px;position:relative;width:100%;z-index:1}.login-container h1{color:var(--text-primary);font-weight:700;margin-bottom:30px;margin-top:0;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);font-weight:500;margin-bottom:8px}.form-group input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:16px;padding:12px 15px;transition:all .3s;width:100%}.form-group input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.error-message{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.login-button{background:var(--primary-gradient);border:none;border-radius:10px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px;transition:all .3s;width:100%}.login-button:hover{box-shadow:0 8px 20px #667eea80;transform:translateY(-2px)}.login-hint{border-top:1px solid #edf2f7;color:var(--text-secondary);font-size:14px;margin-top:25px;padding-top:20px;text-align:center}.admin-create-post,.admin-dashboard{background-color:initial;min-height:100vh;padding-bottom:40px}.admin-header{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#fffc;border:1px solid #fff9;border-radius:16px;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;margin:20px auto 30px;max-width:1400px;padding:20px 30px;transition:all .3s ease;width:calc(100% - 48px)}.admin-header:hover{background:#fffffff2;box-shadow:var(--shadow-lg)}.admin-header h1{-webkit-text-fill-color:#0000;background:var(--primary-gradient);-webkit-background-clip:text;font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin:0}.admin-actions{gap:12px}.admin-main{margin:0 auto;max-width:1400px;padding:0 24px}.btn{align-items:center;border-radius:8px;display:inline-flex;font-size:14px;font-weight:600;justify-content:center;padding:10px 20px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--primary-gradient);box-shadow:0 4px 12px #667eea4d;color:#fff}.btn-primary:hover{box-shadow:0 8px 16px #667eea80}.btn-secondary{background:#fff;border:1px solid #e2e8f0;box-shadow:var(--shadow-sm);color:var(--text-primary)}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e0;box-shadow:var(--shadow-md)}.btn-edit{background-color:#4299e1;border-radius:6px;box-shadow:0 2px 4px #4299e14d;color:#fff;font-size:12px;padding:6px 12px}.btn-edit:hover{background-color:#3182ce;box-shadow:0 4px 8px #4299e166}.btn-delete{background-color:#f56565;border-radius:6px;box-shadow:0 2px 4px #f565654d;font-size:12px;padding:6px 12px}.btn-delete:hover{background-color:#e53e3e;box-shadow:0 4px 8px #f5656566}.btn-view{background-color:#48bb78;border-radius:6px;box-shadow:0 2px 4px #48bb784d;color:#fff;font-size:12px;padding:6px 12px}.btn-view:hover{background-color:#38a169;box-shadow:0 4px 8px #48bb7866}.search-bar{align-items:center;background:#fff;border:1px solid #00000005;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:30px;padding:15px 20px}.search-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:50px;font-size:15px;max-width:400px;padding:12px 20px;transition:all .2s}.search-input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.stats{background-color:#edf2f7;border:none;border-radius:20px;color:var(--text-secondary);font-size:14px;font-weight:500;padding:8px 16px}.posts-table{background-color:#fff;border:1px solid #00000005;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.posts-table table{border-collapse:collapse;width:100%}.posts-table td,.posts-table th{border-bottom:1px solid #edf2f7;padding:18px 24px;text-align:left}.posts-table th{background-color:#f8fafc;color:var(--text-secondary);font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.posts-table td:last-child,.posts-table th:last-child{white-space:nowrap;width:1%}.posts-table tr{transition:background-color .2s}.posts-table tr:hover{background-color:#f7fafc}.post-title{color:var(--text-primary);font-size:1rem;font-weight:600;text-decoration:none;transition:color .2s}.post-title:hover{color:#667eea}.post-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{border-radius:12px;font-size:.8rem;padding:4px 10px}.action-buttons{display:flex;gap:8px;white-space:nowrap}.btn-delete,.btn-edit,.btn-view{min-width:-webkit-fit-content;min-width:fit-content;white-space:nowrap}.post-form{background-color:#fff;border:1px solid #00000005;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:40px}.form-section{margin-bottom:30px}.form-section label{color:var(--text-primary);display:block;font-size:16px;font-weight:600;margin-bottom:12px}.form-section input[type=text]{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:16px;padding:14px 18px;transition:all .2s;width:100%}.form-section input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.tags-input{display:flex;gap:10px;max-width:100%}.tags-input input{flex:1 1}.tags-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.form-actions{border-top:1px solid #edf2f7;display:flex;gap:15px;justify-content:flex-end;margin-top:40px;padding-top:30px}.loading{background:#fff;color:var(--text-secondary);font-size:18px;padding:60px}.loading,.no-posts{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center}.no-posts{background-color:#fff;border:1px solid #00000005;padding:80px}.no-posts p{color:var(--text-secondary);font-size:18px;margin-bottom:25px}@media (max-width:768px){.admin-header{flex-direction:column;gap:20px;margin-top:10px;padding:20px}.admin-actions{flex-wrap:wrap;justify-content:center;width:100%}.admin-main{padding:15px}.search-bar{align-items:stretch;flex-direction:column;gap:15px}.search-input{max-width:100%}.posts-table table{display:block;overflow-x:auto}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.admin-comments{margin:0 auto;max-width:800px;padding:20px}.comment-card{background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:15px;padding:15px;transition:all .3s ease}.comment-card.is-top{background-color:#fffaf0;border-left:4px solid #f6ad55}.comment-header{margin-bottom:10px}.user-info{align-items:center;display:flex;gap:10px}.avatar{border-radius:50%;height:40px;width:40px}.nickname{display:block;font-weight:700}.qq{color:#666;font-size:.8em}.date{color:#999;font-size:.9em}.comment-content{background:#f9f9f9;border-radius:4px;margin:10px 0 15px;padding:10px}.comment-actions{gap:10px;justify-content:flex-end}.btn{border:none;border-radius:4px;cursor:pointer;font-size:.9em;padding:6px 12px;transition:background .2s}.btn-approve{background:#4caf50;color:#fff}.btn-approve:hover{background:#45a049}.btn-reject{background:#ff9800;color:#fff}.btn-reject:hover{background:#f57c00}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover{background:#d32f2f}.btn-info{background:#4299e1;color:#fff}.btn-info:hover{background:#3182ce}.btn-warning{background:#ecc94b;color:#744210}.btn-warning:hover{background:#d69e2e}.no-comments{color:#999}.error,.loading,.no-comments{padding:40px;text-align:center}.error,.loading{color:#666}.error{color:#f44336}.badge{border-radius:4px;display:inline-block;font-size:.75em;font-weight:400;margin-left:8px;padding:2px 6px}.badge-comment{background-color:#e3f2fd;border:1px solid #bbdefb;color:#1976d2}.badge-message{background-color:#f3e5f5;border:1px solid #e1bee7;color:#7b1fa2}.badge-top{background-color:#fffaf0;border:1px solid #fbd38d;color:#dd6b20}.tabs{border-bottom:1px solid #eee;display:flex;margin-bottom:20px}.tab-btn{background:none;border:none;color:#666;cursor:pointer;font-size:1rem;padding:10px 20px;position:relative}.tab-btn:hover{color:#333}.tab-btn.active{color:#3182ce;font-weight:700}.tab-btn.active:after{background:#3182ce;bottom:-1px;content:"";height:2px;left:0;position:absolute;width:100%}.admin-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.search-input{border:1px solid #ddd;border-radius:6px;flex:1 1;font-size:.95rem;min-width:220px;padding:8px 10px}.btn-secondary{background:#e2e8f0;color:#1a202c}.btn-secondary:hover{background:#cbd5e0}.selected-count{color:#666;font-size:.9em;margin-left:auto}.select-checkbox{cursor:pointer;height:18px;width:18px}.markdown-editor{border:1px solid #ddd;border-radius:8px;overflow:hidden;width:100%}.editor-toolbar{background-color:#f5f5f5;border-bottom:1px solid #ddd;display:flex;flex-wrap:wrap;gap:8px;padding:10px}.editor-toolbar button{background-color:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:14px;padding:6px 12px;transition:all .2s}.editor-toolbar button:hover{background-color:#f0f0f0;border-color:#999}.editor-container{display:flex;min-height:500px}.editor-section,.preview-section{border-right:1px solid #ddd;flex:1 1;min-width:0;padding:20px}.preview-section{background-color:#f9f9f9;border-right:none}.editor-section h3,.preview-section h3{color:#333;margin-bottom:15px;margin-top:0}.editor-textarea{border:1px solid #ddd;border-radius:4px;font-family:Courier New,monospace;font-size:14px;height:400px;line-height:1.6;padding:15px;resize:vertical;width:100%}.editor-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.preview-content{background-color:#fff;border:1px solid #ddd;border-radius:4px;height:400px;overflow-x:hidden;overflow-y:auto;padding:15px}.preview-content h1{color:#333;font-size:2rem;margin:20px 0 15px}.preview-content h2{color:#333;font-size:1.5rem;margin:18px 0 12px}.preview-content h3{color:#333;font-size:1.25rem;margin:15px 0 10px}.preview-content p{line-height:1.6;margin:10px 0}.preview-content ol,.preview-content ul{margin:10px 0;padding-left:20px}.preview-content li{margin:5px 0}.preview-content blockquote{border-left:4px solid #ddd;color:#666;margin:10px 0;padding-left:15px}.preview-content pre{border-radius:4px;margin:15px 0;overflow-x:auto}.preview-content code{background-color:#f5f5f5;border-radius:3px;font-family:Courier New,monospace;font-size:.9em;padding:2px 4px}.code-block-wrapper{border-radius:8px;margin:1rem 0}.code-block-header{font-size:.8rem;padding:.4rem .6rem}.copy-button{font-size:.8rem;padding:3px 8px}@media (max-width:768px){.editor-container{flex-direction:column}.editor-section,.preview-section{border-bottom:1px solid #ddd;border-right:none}}.system-monitor{padding:20px}.monitor-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.monitor-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:20px}.monitor-card h3{border-bottom:1px solid #edf2f7;color:#4a5568;margin-bottom:15px;margin-top:0;padding-bottom:10px}.monitor-value{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:5px}.monitor-detail{color:#718096;font-size:.9rem;margin-bottom:15px}.progress-bar-bg{background:#edf2f7;border-radius:5px;height:10px;overflow:hidden}.progress-fill{height:100%;transition:width .5s ease-in-out}.system-info-list{list-style:none;margin:0;padding:0}.system-info-list li{border-bottom:1px solid #edf2f7;color:#4a5568;padding:8px 0}.system-info-list li:last-child{border-bottom:none}.system-info-list strong{color:#2d3748;margin-right:8px}.monitor-error,.monitor-loading{color:#718096;font-size:1.2rem;padding:40px;text-align:center}.monitor-error{color:#e53e3e}.admin-layout{background-color:#f7fafc;display:flex;min-height:100vh}.admin-sidebar{background-color:#fff;border-right:1px solid #e2e8f0;bottom:0;box-shadow:0 2px 8px #0000000a;color:#2d3748;display:flex;flex-direction:column;left:0;overflow-y:auto;position:fixed;top:0;width:250px;z-index:100}.sidebar-header{background:var(--primary-gradient);border-bottom:1px solid #e2e8f0;color:#fff;padding:20px}.sidebar-header h2{color:#fff;font-size:1.4rem;letter-spacing:.5px;margin:0}.sidebar-nav{display:flex;flex-direction:column;padding:20px 0}.sidebar-link{align-items:center;background:none;border:none;border-left:3px solid #0000;border-radius:0;color:#4a5568;cursor:pointer;display:flex;font-size:1rem;padding:12px 20px;text-align:left;text-decoration:none;transition:all .2s;width:100%}.sidebar-link:hover{background-color:#f1f5f9;color:#2d3748}.sidebar-link.active{background-color:#edf2f7;border-left-color:#667eea;color:#2d3748}.sidebar-link .icon{font-size:1.2rem;margin-right:10px}.logout-btn{color:#e53e3e;margin-top:auto}.logout-btn:hover{background-color:#fff5f5;color:#c53030}.back-blog-btn{color:#2b6cb0}.back-blog-btn:hover{background:#ebf8ff;color:#2b6cb0}.admin-content{flex:1 1;margin-left:250px;padding:30px;width:calc(100% - 250px)}@media (max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{height:auto;position:relative;width:100%;z-index:1}.admin-content{margin-left:0;width:100%}.sidebar-nav{flex-direction:row;flex-wrap:wrap;justify-content:center;padding:10px}.sidebar-link{border-bottom:3px solid #0000;border-left:none;border-radius:4px;margin:5px;padding:8px 15px;width:auto}.sidebar-link.active{border-bottom-color:#63b3ed;border-left:none}}.comment-section{animation:fadeIn .5s ease-out;border-top:1px solid #edf2f7;margin-top:4rem;padding-top:3rem}.comment-section h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:2rem}.comment-author{font-size:1rem}.top-badge{background-color:#f3e5f5;border:1px solid #e1bee7;color:#7b1fa2}.comment-location{align-items:center;background-color:#edf2f7;border-radius:20px;color:#718096;display:flex;font-size:.75rem;font-weight:500;padding:3px 10px}.location-icon{font-size:1em;margin-right:4px}.comment-text{color:#4a5568;font-size:.95rem;line-height:1.6}.comment-text p{margin-bottom:.5rem}.comment-text p:last-child{margin-bottom:0}.comment-text a{color:#667eea;text-decoration:none}.comment-text a:hover{text-decoration:underline}.comment-text img{border-radius:8px;margin-top:.5rem;max-width:100%}.comment-text pre{background:#f7fafc;border-radius:4px;font-size:.85rem;margin:.5rem 0;overflow-x:auto;padding:.5rem}.comment-text code{background:#edf2f7;border-radius:3px;font-family:monospace;font-size:.85em;padding:.2rem .4rem}.comment-actions{margin-top:1rem}.reply-btn{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:600;padding:0;transition:color .2s}.reply-btn:hover{color:#764ba2;text-decoration:underline}.reply-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.reply-modal{animation:slideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;padding:2rem;width:90%}.reply-modal-header{align-items:center;border-bottom:1px solid #edf2f7;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.reply-modal-title{align-items:center;display:flex;gap:12px}.reply-modal-header h4{color:#2d3748;font-size:1.25rem;font-weight:700;margin:0}.reply-target-info{align-items:center;background-color:#f7fafc;border:1px solid #edf2f7;border-radius:20px;display:flex;gap:8px;padding:4px 12px}.reply-target-avatar{border:1px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0000001a;height:24px;object-fit:cover;width:24px}.reply-target-name{color:#667eea;font-size:.95rem;font-weight:600}.close-btn{background:none;border:none;color:#a0aec0;cursor:pointer;font-size:2rem;line-height:1;padding:0;transition:color .2s}.close-btn:hover{color:#e53e3e}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.cancel-btn{background:#edf2f7;border:none;border-radius:50px;color:#4a5568;cursor:pointer;font-weight:600;padding:.8rem 2rem;transition:all .2s}.cancel-btn:hover{background:#e2e8f0}.loading,.no-comments{background:#f7fafc;border:2px dashed #cbd5e0;border-radius:12px;color:#718096;padding:3rem;text-align:center}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.emoji-trigger{bottom:10px;right:10px;z-index:10}.emoji-btn{padding:5px}.emoji-btn:hover{background-color:#f0f0f0}.emoji-picker-container{margin-bottom:10px;z-index:100}.emoji-picker-overlay{z-index:90}.emoji-picker-wrapper{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:100}@media (max-width:640px){.comment-section{margin-top:2rem;padding-top:2rem}.comment-section h3{font-size:1.25rem;margin-bottom:1.5rem}.comment-form{margin-bottom:2rem;padding:1rem}.form-row{flex-direction:column;gap:1rem}.comment-item{flex-direction:column;gap:.8rem;padding:1rem}.comment-item .comment-avatar{align-items:center;display:flex;gap:.5rem;margin-bottom:0}.mobile-user-info{align-items:center;display:flex!important;flex-wrap:wrap;gap:.5rem}.comment-avatar img{height:36px;width:36px}.comment-header{align-items:flex-start;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.comment-header .comment-author-info{display:none}.comment-info{color:#a0aec0;font-size:.8rem;gap:.5rem;justify-content:flex-start;margin-top:.2rem;width:100%}.comment-date{font-size:.75rem}.comment-location{font-size:.7rem;padding:2px 6px}.comment-text{font-size:.9rem;word-break:break-word}.replies-list{border-left:2px solid #edf2f7;margin-top:.8rem;padding-left:.5rem}.reply-item{background:#f8fafc;border-radius:8px;margin-top:.8rem;padding:.8rem}.reply-modal{margin:0 auto;padding:1.25rem;width:95%}.reply-modal-header{margin-bottom:1.5rem}}.reply-modal-target{color:#667eea;margin-left:4px}@keyframes highlight-fade{0%{background-color:#4caf5033}to{background-color:initial}}.highlight-comment{animation:highlight-fade 3s ease-out;border-radius:8px}.qq-input-wrapper{align-items:center;display:flex;gap:12px;position:relative}.qq-input-wrapper input{background-color:#f7fafc;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;flex:1 1;font-size:.95rem;padding:.8rem 1rem;transition:all .2s;width:100%}.qq-input-wrapper input:focus{background-color:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.qq-avatar-preview{background-color:#f7fafc;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 6px #0000001a;flex-shrink:0;height:44px;overflow:hidden;transition:transform .2s;width:44px}.qq-avatar-preview:hover{transform:scale(1.1)}.qq-avatar-preview img{height:100%;object-fit:cover;width:100%}.guestbook-container{animation:fadeIn .6s ease-out;margin:0 auto;max-width:900px;padding:2rem 0}.guestbook-header{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:3rem;padding:2rem;text-align:center}.guestbook-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:1rem}.guestbook-header p{color:#718096;font-size:1.1rem}.guestbook-info-section{display:flex;flex-direction:column;gap:2rem;margin-bottom:3rem}.info-card{background:#0000;padding:1rem}.info-card h3{align-items:center;color:#2d3748;display:flex;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.info-card h3:before{color:#f56565;margin-right:.5rem}.basic-info ul{border-left:4px solid #e2e8f0;list-style:none;margin:0;padding:0 0 0 1.5rem}.basic-info li{align-items:center;color:#4a5568;display:flex;flex-wrap:wrap;font-size:1.05rem;margin-bottom:1rem}.basic-info li:before{color:#2d3748;content:"•";font-size:1.2rem;font-weight:700;margin-right:.5rem}.info-label{color:#4a5568;font-weight:500}.info-value{color:#2d3748}.info-link{color:#4a5568;text-decoration:none;transition:color .2s}.info-link:hover{color:#667eea;text-decoration:underline}.links-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.link-card{align-items:center;background:#fff;border:1px solid #0000;border-radius:12px;display:flex;gap:1rem;padding:1rem;text-decoration:none;transition:all .3s ease}.link-card:hover{background:#fff;box-shadow:0 10px 15px -3px #0000001a;transform:translateY(-2px)}.link-avatar{border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:60px;object-fit:cover;width:60px}.link-content{flex:1 1;overflow:hidden}.link-name{color:#2d3748;font-size:1.1rem;font-weight:700;margin:0 0 .25rem}.link-desc{color:#718096;font-size:.9rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-badge{background-color:#fffaf0;border:1px solid #fbd38d;border-radius:12px;color:#dd6b20;display:inline-block;font-size:.75rem;margin-left:8px;padding:2px 8px}.comment-item.is-top{background:#fffaf0;border-left:4px solid #f6ad55}.message-board{border-top:none;margin-top:0;padding-top:0}.comment-form{background:#fff;border:1px solid #00000005;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-bottom:3rem;padding:2rem}.form-row{display:flex;gap:1.5rem;margin-bottom:1.5rem}.form-group{flex:1 1}.form-group label{color:#4a5568;display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-group>input,.textarea-wrapper>textarea{background-color:#f7fafc;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;font-size:.95rem;padding:.8rem 1rem;transition:all .2s;width:100%}.form-group>input:focus,.textarea-wrapper>textarea:focus{background-color:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.textarea-wrapper{position:relative}.textarea-wrapper>textarea{line-height:1.6;min-height:120px;resize:vertical}.emoji-trigger{bottom:12px;position:absolute;right:12px}.emoji-btn{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;padding:4px;transition:background-color .2s}.emoji-btn:hover{background-color:#f0f4f8}.emoji-picker-container{bottom:100%;margin-bottom:8px;position:absolute;right:0;z-index:1000}.emoji-picker-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.emoji-picker-wrapper{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:8px 8px 4px;position:relative;z-index:1000}.emoji-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.emoji-tab{background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;color:#4a5568;cursor:pointer;flex:1 1;font-size:12px;min-width:60px;padding:4px 6px}.emoji-tab.active{background:#667eea;border-color:#667eea;color:#fff}.emoji-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(8,1fr);max-height:220px;overflow-y:auto;padding:4px 2px 2px}.emoji-button{background:#0000;border:none;border-radius:8px;cursor:pointer;font-size:20px;line-height:1;padding:4px 0}.emoji-button:hover{background:#edf2f7}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.8rem 2rem;transition:all .3s}.submit-btn:hover{box-shadow:0 8px 20px #667eea80;transform:translateY(-2px)}.submit-btn:disabled{background:#cbd5e0;box-shadow:none;cursor:not-allowed;transform:none}.comments-list{display:flex;flex-direction:column;gap:2rem}.comment-item{background:#fff;border:1px solid #0000;border-radius:16px;box-shadow:0 2px 4px #0000000a;display:flex;gap:1.2rem;padding:1.5rem;transition:all .2s}.comment-item:hover{border-color:#667eea1a;box-shadow:0 10px 15px -3px #0000001a;transform:translateY(-2px)}.reply-item{background:#f8fafc;border-left:4px solid #667eea;margin-top:1rem}.replies-list{border-left:2px solid #edf2f7;margin-top:1rem;padding-left:2rem}.comment-avatar img{border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:50px;object-fit:cover;width:50px}.comment-content-wrapper{flex:1 1}.comment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.8rem}.comment-author-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.reply-to-text{color:#718096;font-size:.95rem;font-weight:500}.reply-at{color:#667eea;font-weight:600;margin-right:4px}.comment-info{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.comment-author{color:#2d3748;font-size:1.05rem;font-weight:700}.comment-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:2px 8px}.comment-date{color:#a0aec0;font-size:.85rem}.comment-body{color:#4a5568;line-height:1.6;margin-bottom:.8rem}.comment-actions{display:flex;gap:1rem}.action-btn{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:.9rem;gap:4px;padding:4px 8px;transition:all .2s}.action-btn:hover{background-color:#ebf4ff;color:#667eea}.action-btn.delete:hover{background-color:#fff5f5;color:#e53e3e}.loading-container{align-items:center;color:#718096;display:flex;flex-direction:column;padding:3rem}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:1rem;width:40px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.guestbook-container{padding:1rem}.guestbook-header{padding:1.5rem}.guestbook-header h2{font-size:2rem}.form-row{flex-direction:column;gap:1rem}.links-grid{grid-template-columns:1fr}.emoji-picker-container{bottom:auto;left:50%;max-width:350px;position:fixed;right:auto;top:50%;transform:translate(-50%,-50%);width:90%}.emoji-picker-wrapper aside.EmojiPickerReact.epr-main{height:350px!important;max-width:100%!important}}:root{--primary-gradient:linear-gradient(135deg,#667eea,#764ba2);--secondary-gradient:linear-gradient(135deg,#ff9a9e,#fecfef 99%,#fecfef);--text-primary:#2d3748;--text-secondary:#718096;--bg-body:#f7fafc;--bg-card:#fff;--shadow-sm:0 1px 3px #0000001f,0 1px 2px #0000003d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-hover:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--radius-md:12px;--radius-lg:16px;--font-main:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background-color:initial;color:#2d3748;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-main);line-height:1.7;position:relative}body:before{animation:bgRotate 60s linear infinite;background:radial-gradient(circle at 20% 30%,#667eea14 0,#0000 40%),radial-gradient(circle at 80% 70%,#764ba214 0,#0000 40%),radial-gradient(circle at 40% 80%,#667eea14 0,#0000 40%),#f7fafc;background:radial-gradient(circle at 20% 30%,#667eea14 0,#0000 40%),radial-gradient(circle at 80% 70%,#764ba214 0,#0000 40%),radial-gradient(circle at 40% 80%,#667eea14 0,#0000 40%),var(--bg-body);content:"";height:200%;left:-50%;pointer-events:none;position:fixed;top:-50%;width:200%;z-index:-1}@keyframes bgRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app{display:flex;flex-direction:column;min-height:100vh}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes gradientBG{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.header{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border-bottom:1px solid #0000000d;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);z-index:1000}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.logo a{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;font-size:1.5rem;font-weight:800;letter-spacing:-.5px;text-decoration:none}.nav{display:flex;gap:1.5rem}.nav-link{border-radius:8px;color:#718096;color:var(--text-secondary);font-weight:500;padding:.5rem 1rem;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.nav-link.active,.nav-link:hover{background-color:#667eea14;color:#667eea}.main-content{animation:fadeIn .6s ease-out;flex:1 1;padding:3rem 0}.container{margin:0 auto;max-width:1200px;padding:0 24px}.hero{animation:gradientBG 6s ease infinite;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);background-size:200% 200%;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);color:#fff;margin-bottom:4rem;overflow:hidden;padding:5rem 2rem;position:relative;text-align:center}.hero:before{background:#0000001a;bottom:0;content:"";left:0;position:absolute;right:0;top:0}.hero h2{font-size:2.5rem;font-weight:800;margin-bottom:1rem;position:relative;text-shadow:0 2px 4px #0003}.subtitle{font-size:1.1rem;font-weight:400;opacity:.95;position:relative}.page-title{color:#2d3748;color:var(--text-primary);display:inline-block;font-size:2rem;font-weight:800;letter-spacing:-.5px;margin-bottom:2.5rem;position:relative}.page-title:after{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border-radius:2px;bottom:-8px;content:"";height:4px;left:0;position:absolute;width:40%}.recent-posts h3{color:#2d3748;color:var(--text-primary);display:inline-block;font-size:2rem;font-weight:800;letter-spacing:-.5px;margin-bottom:2.5rem;position:relative}.recent-posts h3:after{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border-radius:2px;bottom:-8px;content:"";height:4px;left:0;position:absolute;width:40%}.posts-grid{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));margin-bottom:4rem}.post-card{background:#fff;background:var(--bg-card);border:1px solid #0000000a;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000000d;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:2.2rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.post-card:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);content:"";height:4px;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.post-card:hover{border-color:#667eea1a;box-shadow:0 15px 35px #0000001a;transform:translateY(-8px)}.post-card:hover:before{opacity:1}.post-date{align-self:flex-start;background:#667eea14;border-radius:6px;color:#667eea;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:1.2rem;padding:.4rem .8rem;text-transform:uppercase}.post-card h4{font-size:1.35rem;font-weight:700;line-height:1.4;margin-bottom:1rem}.post-card h4 a{color:#2d3748;color:var(--text-primary);text-decoration:none;transition:color .2s}.post-card h4 a:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text}.post-card p{color:#718096;flex:1 1;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.read-more{align-items:center;border-top:1px solid #0000000a;color:#667eea;display:inline-flex;font-size:.95rem;font-weight:600;padding-top:1.2rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}.read-more:after{content:"→";margin-left:6px;transition:transform .2s}.read-more:hover:after{transform:translateX(4px)}.archives-container{background:linear-gradient(180deg,#f7fafccc,#ffffffe6);border-radius:16px;border-radius:var(--radius-lg);margin:0 auto;max-width:1200px;padding:24px}.archives-filter{display:none}.archive-group,.archive-year{margin-bottom:2.5rem}.archive-year{border-bottom:1px solid #edf2f7;max-height:2000px;padding-bottom:1.5rem;transition:max-height .3s ease}.archive-year.collapsed{max-height:64px;overflow:hidden}.archive-year-header{align-items:center;background:linear-gradient(135deg,#667eea1f,#764ba21f);border:1px solid #667eea2e;border-radius:14px;box-shadow:0 6px 18px #667eea1f;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:12px 14px}.archive-year-content{max-height:2000px;transition:max-height .3s ease,opacity .3s ease,transform .3s ease}.archive-year-content.collapsed{max-height:0;opacity:0;overflow:hidden;pointer-events:none;transform:translateY(-4px)}.archive-year-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;font-size:1.8rem;font-weight:800}.year-toggle{background:#fff;border:1px solid #667eea40;border-radius:10px;color:#2d3748;color:var(--text-primary);cursor:pointer;font-weight:600;padding:8px 14px;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.year-toggle:hover{box-shadow:0 8px 20px #667eea2e;transform:translateY(-1px)}.archive-month-title{color:#2d3748;color:var(--text-primary);font-size:1.5rem;font-weight:800;margin-bottom:1rem;padding-left:18px;position:relative}.archive-month-title:before{background:#667eea;border-radius:50%;box-shadow:0 0 0 4px #667eea26;content:"";height:8px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:8px}.archive-cards{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.archive-card{background:linear-gradient(180deg,#fff,#f9fafb);border:1px solid #0000000f;border-radius:14px;box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d;box-shadow:var(--shadow-sm);color:#2d3748;color:var(--text-primary);display:block;overflow:hidden;padding:1rem 1.2rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.archive-card:hover{border-color:#667eea47;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.archive-card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-weight:700;margin-bottom:6px;overflow:hidden}.archive-card-date{color:#718096;color:var(--text-secondary);font-size:.9rem}.view-all{margin-top:2rem;text-align:center}.button,.view-all .button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border:none;border-radius:50px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;justify-content:center;padding:.8rem 2.5rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.button:hover{box-shadow:0 8px 20px #667eea99;transform:translateY(-2px)}.empty-state{background:#fff;background:var(--bg-card);border:1px solid #667eea1f;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-top:1rem;padding:2.5rem;text-align:center}.empty-title{color:#2d3748;color:var(--text-primary);font-size:1.4rem;font-weight:800;margin-bottom:.5rem}.empty-desc{color:#718096;color:var(--text-secondary);margin-bottom:1.25rem}.empty-actions{align-items:center;display:inline-flex;gap:10px}.blog-header{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:1fr auto;margin-bottom:1rem}.blog-search-bar{align-items:center;display:inline-flex;gap:8px}.blog-search{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:inset 0 1px 2px #0000000a;color:#2d3748;color:var(--text-primary);min-width:260px;padding:8px 12px}.blog-search-btn{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border:none;border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-weight:600;padding:.6rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.blog-search-btn:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.blog-clear-btn{background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#2d3748;color:var(--text-primary);cursor:pointer;font-weight:600;padding:.6rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.blog-clear-btn:disabled{cursor:not-allowed;opacity:.6}.blog-post{background:#fff;background:var(--bg-card);border:1px solid #00000008;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 2px 10px #00000008;display:flex;flex-direction:column;margin-bottom:2rem;padding:2.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.blog-post:hover{border-color:#667eea33;box-shadow:0 10px 25px #00000014;transform:translateY(-2px)}.blog-post .post-header{margin-bottom:1rem}.blog-post h3{font-size:1.6rem;font-weight:800;line-height:1.3;margin-bottom:.5rem}.blog-post h3 a{color:#2d3748;color:var(--text-primary);text-decoration:none;transition:all .2s}.blog-post h3 a:hover{color:#667eea}.blog-post .post-date{background:#0000;color:#a0aec0;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem;padding:0}.blog-post p{color:#4a5568;font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}.blog-post .read-more{align-self:flex-start;background:#667eea1a;border-radius:50px;border-top:none;padding:.6rem 1.2rem;transition:all .3s ease;width:auto}.blog-post .read-more:hover{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);box-shadow:0 4px 12px #667eea4d;color:#fff;transform:translateY(-2px)}.blog-post .read-more:hover:after{transform:translateX(2px)}.post-container{background:#fff;background:var(--bg-card);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin-top:-2rem;max-width:800px;padding:3rem}.post-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;font-size:2.25rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.post-meta{border-bottom:1px solid #edf2f7;color:#718096;color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem;padding-bottom:1rem}.post-meta span{align-items:center;display:inline-flex;margin-right:1.5rem}.tags{margin-bottom:2.5rem}.tag{background-color:#edf2f7;border-radius:20px;color:#4a5568;font-size:.85rem;font-weight:500;padding:.4rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.tag:hover{background-color:#e2e8f0;color:#2d3748}.post-body{color:#2d3748;font-size:1.05rem;line-height:1.8}.post-body h2{color:#1a202c;font-size:1.6rem;font-weight:700;margin-bottom:1.5rem;margin-top:3rem}.post-body h3{color:#2d3748;font-size:1.3rem;margin-top:2.5rem}.post-body p{margin-bottom:1.6rem}.post-body blockquote{background:#f7fafc;border-left:4px solid #667eea;border-radius:0 8px 8px 0;color:#4a5568;font-style:italic;margin:2rem 0;padding:1.5rem 2rem}.post-body pre{background:#2d3748;border-radius:12px;box-shadow:inset 0 2px 4px #0000001a;color:#e2e8f0;overflow-x:auto;padding:1.5rem}.post-body code{font-family:Fira Code,Courier New,monospace}.code-block-wrapper{background:#1f2937;border-radius:12px;box-shadow:inset 0 2px 4px #00000014;margin:1.25rem 0;overflow:hidden}.code-block-header{align-items:center;background:#111827;color:#e5e7eb;display:flex;font-size:.85rem;justify-content:space-between;padding:.5rem .75rem}.code-language{opacity:.8;text-transform:uppercase}.copy-button{background:#0000;border:1px solid #e5e7eb4d;border-radius:6px;color:#e5e7eb;cursor:pointer;font-size:.85rem;padding:4px 10px}.copy-button:hover{background:#ffffff14;border-color:#e5e7eb99}.copy-button.copied{background:#34d399;border-color:#10b981;color:#083344}.code-block-content{overflow-x:auto}.back-to-top{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:1px solid #ffffff59;border-radius:50%;bottom:24px;box-shadow:0 12px 24px #667eea73;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;opacity:0;position:fixed;right:24px;transform:translateY(12px);transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease;width:56px;z-index:1000}.back-to-top.show{opacity:1;transform:translateY(0)}.back-to-top:hover{box-shadow:0 18px 36px #667eea99}.back-to-top svg{filter:drop-shadow(0 2px 2px rgba(0,0,0,.25));height:60px;width:60px}.post-body img{border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin:1rem auto}.post-body img,.preview-content img{cursor:zoom-in;display:block;height:auto;max-width:100%}.preview-content img{border-radius:6px;box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d;box-shadow:var(--shadow-sm);margin:.75rem auto}.lightbox-overlay{align-items:center;background:#0009;bottom:0;cursor:zoom-out;display:flex;justify-content:center;left:0;padding:2vw;position:fixed;right:0;top:0;touch-action:none;z-index:2000}.lightbox-image{border-radius:10px;box-shadow:0 10px 30px #00000080;max-height:92vh;max-width:92vw;-webkit-user-select:none;user-select:none;will-change:transform}.lightbox-toolbar{align-items:center;display:flex;gap:10px;position:absolute;right:16px;top:16px;z-index:2100}.lightbox-info{background:#0000008c;border-radius:8px;color:#fff;font-size:.9rem;padding:6px 10px}.lightbox-btn{background:#ffffffe6;border:1px solid #ffffffb3;border-radius:8px;box-shadow:0 2px 8px #00000026;color:#1f2937;cursor:pointer;font-weight:600;padding:6px 12px}.lightbox-btn:hover{background:#fff}.lightbox-btn.close{background:#f56565;border-color:#f56565;color:#fff}.lightbox-btn.close:hover{background:#e53e3e}.footer{background-color:initial;padding:2rem 0}.about-container{margin:0 auto;max-width:900px}.about-card{animation:fadeIn .6s ease-out;background:#fff;background:var(--bg-card);border:1px solid #00000005;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:3rem 4rem}.about-header{border-bottom:1px solid #edf2f7;margin-bottom:3.5rem;padding-bottom:2.5rem;text-align:center}.about-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;font-size:2.5rem;font-weight:800;letter-spacing:-.5px;margin-bottom:.8rem}.about-header .subtitle{color:#718096;color:var(--text-secondary);font-size:1.1rem}.about-section{margin-bottom:3.5rem}.about-section:last-child{margin-bottom:0}.about-section h3{align-items:center;color:#2d3748;color:var(--text-primary);display:flex;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.about-section h3:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border-radius:2px;content:"";height:24px;margin-right:12px;width:4px}.about-section p{color:#718096;color:var(--text-secondary);font-size:1.05rem;line-height:1.8}.skill-tags{display:flex;flex-wrap:wrap;gap:12px}.skill-tag{background:#f8fafc;border:1px solid #e2e8f0;cursor:default;font-size:.95rem;padding:.6rem 1.2rem;transition:all .2s ease}.skill-tag:hover{background:#fff;border-color:#cbd5e0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#667eea;transform:translateY(-3px)}.contact-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.contact-item{align-items:center;background:#f8fafc;border:1px solid #0000;border-radius:12px;border-radius:var(--radius-md);display:flex;padding:1.2rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.contact-item:hover{background:#fff;border-color:#e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.contact-label{color:#718096;color:var(--text-secondary);font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;width:80px}.contact-value{color:#2d3748;color:var(--text-primary);font-weight:500;overflow-wrap:anywhere;text-decoration:none;transition:color .2s;word-break:break-all}.contact-value:hover{color:#667eea}@media (max-width:768px){.about-card{padding:2rem}.about-header h2{font-size:2rem}.contact-list{grid-template-columns:1fr}.contact-item{align-items:flex-start;flex-direction:column;gap:.5rem}.contact-label{width:auto}.contact-value{display:block;width:100%}}.api-status{font-size:.85rem;font-weight:500}.status{border-radius:20px;padding:4px 10px}.status.connected{background-color:#48bb7833;color:#2f855a}.status.disconnected{background-color:#f5656533;color:#c53030}.error,.loading,.no-posts{background:#fff;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d;box-shadow:var(--shadow-sm);padding:3rem;text-align:center}.error{background:#fff5f5;border:1px solid #feb2b2;color:#c53030}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}.footer{color:#718096;color:var(--text-secondary);font-size:.85rem;margin-top:auto;padding:2rem;text-align:center}.mobile-menu-btn{background:none;border:none;cursor:pointer;display:none;padding:10px;z-index:1001}.hamburger{display:block;position:relative}.hamburger,.hamburger:after,.hamburger:before{background-color:#2d3748;background-color:var(--text-primary);height:2px;transition:all .3s ease-in-out;width:24px}.hamburger:after,.hamburger:before{content:"";position:absolute}.hamburger:before{transform:translateY(-8px)}.hamburger:after{transform:translateY(8px)}.hamburger.active{background-color:initial}.hamburger.active:before{transform:rotate(45deg)}.hamburger.active:after{transform:rotate(-45deg)}@media (max-width:768px){.header{padding:.8rem 0}.header-content{padding:0 16px}.logo a{font-size:1.25rem}.api-status{display:none}.mobile-menu-btn{display:block}.nav{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#fffffffa;box-shadow:0 10px 15px -3px #0000001a;flex-direction:column;gap:1.5rem;left:0;opacity:0;padding:2rem;pointer-events:none;position:fixed;top:60px;transform:translateY(-150%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:100%}.nav.active{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-link{font-size:1.1rem;padding:1rem;text-align:center;width:100%}.container{padding:0 16px}.blog-header{gap:14px;grid-template-columns:1fr;justify-items:stretch}.blog-search-bar{display:flex;flex-wrap:wrap;gap:10px;width:100%}.blog-search{flex:1 1 100%;min-width:0;width:100%}.blog-clear-btn,.blog-search-btn{flex-basis:calc(50% - 5px);flex-grow:1;flex-shrink:1}.blog-post{padding:1.5rem}.blog-post h3{font-size:1.3rem}.hero{border-radius:12px;border-radius:var(--radius-md);margin-bottom:2.5rem;padding:3rem 1.5rem}.hero h2{font-size:1.8rem}.subtitle{font-size:1rem}.posts-grid{gap:1.5rem;grid-template-columns:1fr;margin-bottom:3rem}.post-card{padding:1.5rem}.post-card h4{font-size:1.15rem}.post-container{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-top:0;padding:1.5rem}.post-content h1{font-size:1.75rem;margin-bottom:1rem}.post-meta{align-items:flex-start;flex-direction:column;gap:.5rem}.post-meta span{margin-right:0}.post-body{font-size:1rem}.post-body h2{font-size:1.4rem;margin-top:2rem}.post-body pre{font-size:.9rem;padding:1rem}.about-card{padding:2rem 1.5rem}.about-header h2{font-size:2rem}.contact-list{grid-template-columns:1fr}}.post-top-badge{background-color:#fffaf0;border:1px solid #fbd38d;border-radius:12px;color:#dd6b20;display:inline-block;font-size:.75rem;margin-left:8px;padding:2px 8px}.not-found{padding:4rem 1rem;text-align:center}.nf-hero{background:#fff;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin:0 auto;max-width:720px;padding:2.5rem 2rem}.nf-code{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;font-size:4rem;font-weight:800;letter-spacing:-2px}.nf-title{color:#2d3748;color:var(--text-primary);font-size:1.8rem;margin-top:.5rem}.nf-desc{color:#718096;color:var(--text-secondary);margin:.75rem 0 1.5rem}.nf-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.button-secondary{background:#edf2f7;color:#2d3748}.button-secondary:hover{background:#e2e8f0}.button-tertiary{background:#fffaf0;border:1px solid #fbd38d;color:#dd6b20}.button-tertiary:hover{background:#feebc8}
/*# sourceMappingURL=main.bc7c5506.css.map*/