@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Fira+Code&display=swap);@media (max-width:768px){.posts-table td:nth-child(3),.posts-table td:nth-child(4),.posts-table td:nth-child(5),.posts-table th:nth-child(3),.posts-table th:nth-child(4),.posts-table th:nth-child(5){display:none}.posts-table td:nth-child(2),.posts-table th:nth-child(2){max-width:none;white-space:normal}.post-title{display:block;line-height:1.5;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-word}.posts-table td,.posts-table th{padding:10px 5px}.action-buttons{display:flex;flex-direction:column;gap:5px}.action-buttons .btn{font-size:12px;margin-right:0!important;padding:6px 10px;width:100%}}@keyframes adminSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes adminFadeIn{0%{opacity:0}to{opacity:1}}@keyframes adminScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.admin-page-animate{animation:adminSlideIn .6s ease-out}.admin-card-animate{animation:adminScaleIn .5s ease-out}.admin-stagger-animate>*{animation:adminFadeIn .5s ease-out backwards}.admin-stagger-animate>:first-child{animation-delay:.1s}.admin-stagger-animate>:nth-child(2){animation-delay:.15s}.admin-stagger-animate>:nth-child(3){animation-delay:.2s}.admin-stagger-animate>:nth-child(4){animation-delay:.25s}.admin-stagger-animate>:nth-child(5){animation-delay:.3s}.admin-stagger-animate>:nth-child(6){animation-delay:.35s}.admin-login{align-items:center;background:#0000;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);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{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#f8fafc66;border:1px solid #e2e8f099;border-radius:10px;font-size:16px;padding:12px 15px;transition:all .3s;width:100%}.form-group input:focus{background:#ffffffb3;border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.error-message{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#fff5f5b3;border:1px solid #feb2b299;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:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);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{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffbf;box-shadow:var(--shadow-lg)}.admin-header h1{-webkit-text-fill-color:#0000;background:var(--primary-gradient);-webkit-background-clip:text;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{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#fff6;border:1px solid #e2e8f099;box-shadow:var(--shadow-sm);color:var(--text-primary)}.btn-secondary:hover{background:#f8fafc99;border-color:#cbd5e0cc;box-shadow:var(--shadow-md)}.btn-info{background-color:#4299e1;border-radius:6px;box-shadow:0 2px 4px #4299e14d;font-size:12px;padding:6px 12px}.btn-info:hover{background-color:#3182ce;box-shadow:0 4px 8px #4299e166}.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;font-size:12px;padding:6px 12px}.btn-view:hover{background-color:#38a169;box-shadow:0 4px 8px #48bb7866}.search-bar{align-items:center;backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border:1px solid #00000005;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:20px;margin-top:10px;padding:15px 20px}.search-input{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#f8fafc66;border:1px solid #e2e8f099;border-radius:50px;font-size:15px;max-width:400px;padding:12px 20px;transition:all .2s}.search-input:focus{background:#ffffffb3;border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.stats{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#edf2f780;border:1px solid #fff3;border-radius:20px;color:var(--text-secondary);font-size:14px;font-weight:500;padding:8px 16px}.posts-table{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);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:#f8fafc80;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:#f7fafc99}.post-title{color:var(--text-primary);font-size:1rem;font-weight:600;text-decoration:none;transition:color .2s}.post-title:hover{color:#667eea}.author-cell{max-width:120px;position:relative}.author-name{border-radius:4px;cursor:help;max-width:100%;overflow:hidden;padding:2px 4px;text-overflow:ellipsis;transition:background-color .2s;white-space:nowrap}.author-name:hover{background-color:#f8fafc}.posts-table tr.is-hidden{background-color:#f8fafc;opacity:.6}.posts-table tr.is-hidden .post-title{color:#a0aec0}.badge-hidden{font-size:.75rem!important;font-weight:500}.btn.btn-warning{background-color:#ed8936;box-shadow:0 2px 4px #ed89364d;color:#fff}.btn.btn-warning:hover{background-color:#dd6b20;box-shadow:0 4px 8px #ed893666}.post-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{align-items:center;background-color:#edf2f7;border:1px solid #e2e8f0;display:inline-flex;gap:8px;padding:6px 12px;transition:all .2s ease}.tag:hover{background-color:#e2e8f0;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.tag-remove{align-items:center;background:none;border:none;border-radius:50%;color:#718096;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;height:18px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:18px}.tag-remove:hover{background-color:#f56565;box-shadow:0 2px 6px #f565654d;color:#fff;transform:scale(1.1)}.tag-remove:active{transform:scale(.95)}.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{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);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{font-size:18px;padding:60px}.loading,.no-posts{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center}.no-posts{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%}.tag{font-size:.8rem;gap:6px;padding:4px 10px}.tag-remove{font-size:12px;height:16px;width:16px}.tags-list{gap:8px}}.admin-comments{margin:0 auto;max-width:1400px;padding:20px;width:100%}.comment-card{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border:1px solid #0000000d;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:15px;padding:15px;transition:all .3s ease}.comment-card.is-top{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#fffaf099;border-left:4px solid #f6ad55}.comment-header{margin-bottom:5px}.user-info{align-items:center;display:flex;gap:10px}.avatar{border:2px solid #fffc;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:40px;width:40px}.user-details{display:flex;flex:1 1;flex-direction:column;justify-content:center;min-width:0}.user-row-primary{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.user-qq-row{color:#666;font-size:.85em;margin-top:2px}.comment-meta-row{align-items:center;color:#666;display:flex;flex-wrap:wrap;font-size:.85em;gap:10px;line-height:1.4;margin-bottom:8px}.nickname{color:#2c3e50;font-size:1rem;font-weight:700}.date-desktop{color:#999;font-size:.9em;margin-left:15px;white-space:nowrap}.date-mobile{display:none}.comment-content{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#f9f9f966;border:1px solid #ffffff4d;border-radius:4px;margin:10px 0 15px;overflow-wrap:anywhere;padding:10px;word-break:break-word}.comment-content img,.comment-content svg{border-radius:8px;max-width:100%;vertical-align:middle}.comment-content img[src*="/emoji/"]{border-radius:0;display:inline-block;height:32px;margin:0 2px;vertical-align:text-bottom;width:32px}.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-view{background:#38b2ac;color:#fff}.btn-view:hover{background:#319795}.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;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}.location{color:#2c3e50}.ip{color:#7f8c8d;font-size:.85em}.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}.filter-controls{background:#fff;background:var(--bg-card,#fff);border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:15px}.filter-group{align-items:center;display:flex;gap:10px}.filter-label{color:#666;font-size:.9em;font-weight:700}.filter-chip{background:#0000;border:1px solid #ddd;border-radius:20px;color:#666;cursor:pointer;font-size:.9em;padding:6px 14px;transition:all .2s}.filter-chip:hover{background:#f5f5f5}.filter-chip.active{background:#e3f2fd;border-color:#bbdefb;color:#1976d2}.comment-group{margin-bottom:30px}.group-title{border-bottom:2px solid #eee;color:#2c3e50;font-size:1.2em;margin-bottom:15px;padding-bottom:10px}.group-count{color:#999;font-size:.8em;font-weight:400}@media (max-width:768px){.admin-comments{padding:10px}.filter-controls{flex-direction:column;gap:15px}.filter-group{overflow-x:auto;padding-bottom:5px;width:100%}.comment-card{padding:10px}.comment-header,.user-info{align-items:flex-start;flex-direction:row;gap:10px}.user-info{display:flex!important;width:100%}.user-info>.select-checkbox{margin-top:5px}.avatar{height:38px;width:38px}.user-details{min-width:0}.user-row-primary{margin-bottom:2px}.nickname{font-size:.95rem;margin-right:5px}.badge{font-size:.7em;padding:1px 4px}.comment-meta-row{color:#7f8c8d;font-size:.75em;gap:8px;line-height:1.4}.date-desktop{display:none}.date-mobile{color:#999;display:block;margin-left:auto;white-space:nowrap}.comment-actions{flex-wrap:wrap}.btn{flex:1 1;font-size:.85em;padding:8px 5px;text-align:center}.admin-actions{gap:8px}.search-input{flex-basis:100%;margin-bottom:5px;width:100%}.admin-actions .btn{flex:1 1 40%;min-width:80px}.selected-count{margin-top:5px;text-align:right;width:100%}}.markdown-editor{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border:1px solid #fff3;border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden;width:100%}.editor-toolbar{background-color:#ffffff4d;border-bottom:1px solid #fff3;display:flex;flex-wrap:wrap;gap:8px;padding:10px}.editor-toolbar button{background-color:#ffffff80;border:1px solid #ffffff4d;border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:14px;padding:6px 12px;transition:all .2s}.editor-toolbar button:hover{background-color:#fffc;border-color:#667eea;color:#667eea}.editor-container{display:flex;min-height:500px}.editor-section,.preview-section{border-right:1px solid #fff3;flex:1 1;min-width:0;padding:20px}.preview-section{background-color:#ffffff1a;border-right:none}.editor-section h3,.preview-section h3{color:var(--text-primary);margin-bottom:15px;margin-top:0}.editor-textarea{background-color:#fff6;border:1px solid #ffffff4d;border-radius:8px;color:var(--text-primary);font-family:Fira Code,Courier New,monospace;font-size:14px;height:400px;line-height:1.6;padding:15px;resize:vertical;transition:all .2s;width:100%}.editor-textarea:focus{background-color:#ffffffb3;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.preview-content{background-color:#fff6;border:1px solid #fff3;border-radius:8px;color:var(--text-primary);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{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:20px}.monitor-card h3{border-bottom:1px solid #edf2f780;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{backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);background:#edf2f780;border:1px solid #fff3;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 #edf2f780;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:initial;display:flex;min-height:100vh}.admin-sidebar{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border-right:1px solid #fff3;bottom:0;box-shadow:0 2px 8px #0000000a;color:#2d3748;display:flex;flex-direction:column;left:0;margin:0;overflow-y:auto;padding:0;position:fixed;top:0;width:250px;z-index:100}.sidebar-header{background:var(--primary-gradient);border-bottom:1px solid #fff3;color:#fff;margin-top:0;overflow:hidden;padding:10px 20px}.sidebar-header h2{color:#fff;font-size:1.4rem;letter-spacing:.5px;margin:0!important}.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:#f1f5f999;color:#2d3748}.sidebar-link.active{background-color:#edf2f799;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:#fff5f599;color:#c53030}.back-blog-btn{color:#2b6cb0}.back-blog-btn:hover{background:#ebf8ff99;color:#2b6cb0}.admin-content{animation:adminFadeIn .3s ease-out;background:#0000;display:flex;flex:1 1;flex-direction:column;margin-left:250px;padding:10px 30px 30px;width:calc(100% - 250px)}.admin-footer{border-top:1px solid #e2e8f0;margin-top:auto;padding:25px 0;text-align:center}.admin-footer p{color:#718096;font-size:13px;margin:0}.admin-footer a{color:#718096;text-decoration:none;transition:color .2s ease}.admin-footer a:hover{color:#667eea}@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-header{display:block;padding:10px;text-align:center}.sidebar-header h2{font-size:1.2rem;margin:0!important}.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}}.emoji-picker-container{bottom:100%;margin-bottom:8px;max-width:90vw;position:absolute;right:0;width:350px;z-index:1000}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.emoji-picker-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.emoji-picker-wrapper{animation:slideUpFade .2s ease-out;backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);background-clip:padding-box;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;overflow:hidden;padding:12px;position:relative;z-index:1000}.emoji-tabs{border-bottom:1px solid #edf2f7;gap:6px;margin-bottom:12px;padding-bottom:8px}.emoji-tab{background:#0000;border:1px solid #0000;border-radius:6px;color:#718096;flex:0 0 auto;font-size:13px;font-weight:500;padding:4px 10px;transition:all .2s}.emoji-tab:hover{background-color:#f7fafc;color:#4a5568}.emoji-tab.active{background-color:#ebf8ff;color:#4299e1;font-weight:600}.emoji-grid{grid-gap:2px;gap:2px;max-height:250px;padding-right:2px}.emoji-grid::-webkit-scrollbar{width:6px}.emoji-grid::-webkit-scrollbar-track{background:#f7fafc;border-radius:3px}.emoji-grid::-webkit-scrollbar-thumb{background-color:#cbd5e0;border-radius:3px}.emoji-grid::-webkit-scrollbar-thumb:hover{background-color:#a0aec0}.emoji-grid::-webkit-scrollbar-corner{background:#0000}.emoji-button{align-items:center;aspect-ratio:1;border-radius:6px;display:flex;font-size:22px;justify-content:center;padding:6px;transition:transform .1s,background-color .1s}.emoji-button img{height:100%;object-fit:contain;width:100%}.emoji-button:hover{background-color:#edf2f7;transform:scale(1.15)}.emoji-button:active{transform:scale(.95)}.emoji-clear-btn{background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;font-size:12px;padding:4px 8px;transition:all .2s}.emoji-clear-btn:hover{background-color:#edf2f7;color:#e53e3e}.emoji-empty-state{align-items:center;color:#a0aec0;display:flex;flex-direction:column;font-size:.9rem;gap:.5rem;grid-column:1/-1;padding:2rem 1rem;text-align:center}.emoji-empty-icon{font-size:2rem;margin-bottom:4px;opacity:.5}.emoji-preview-bubble{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 15px #00000026;display:flex;font-size:48px;height:80px;justify-content:center;padding:8px;pointer-events:none;position:fixed;transform:translate(-50%,calc(-100% - 12px));width:80px;z-index:10002}.emoji-preview-bubble img{height:100%;object-fit:contain;width:100%}@media (max-width:768px){.emoji-picker-container{animation:slideUpFade .2s ease-out;bottom:100%;left:auto;margin-bottom:8px;max-width:90vw;position:absolute;right:0;top:auto;transform:none;width:300px;z-index:10001}@media (max-width:350px){.emoji-picker-container{right:-20px}}}.emoji-textarea-wrapper{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#f7fafc99;border:2px solid #e2e8f0;border-radius:10px;position:relative;transition:all .2s;width:100%}.emoji-textarea-wrapper:focus-within{background-color:#ffffffd9;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.emoji-content-editable{word-wrap:break-word;color:#2d3748;font-size:.95rem;line-height:1.6;outline:none;overflow-y:auto;padding:.8rem 1rem;white-space:pre-wrap;width:100%}.placeholder{color:#a0aec0;font-size:.95rem;left:1rem;pointer-events:none;position:absolute;top:.8rem}.emoji-inline{height:32px;margin:0 1px;width:32px}.emoji-inline,.unicode-emoji-input{display:inline-block;vertical-align:sub}.unicode-emoji-input{font-family:Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-size:32px;line-height:1}.emoji-zoom-container{-webkit-tap-highlight-color:transparent;cursor:pointer;display:inline-block;position:relative;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);z-index:1}.emoji-zoom-container.zoomed,.emoji-zoom-container:hover{transform:scale(2.5);z-index:100}.emoji-zoom-container img{border-radius:0;height:32px;margin:0;pointer-events:none;vertical-align:text-bottom;width:32px}.emoji-zoom-container.unicode-emoji{font-size:32px;line-height:1;vertical-align:middle}.expandable-comment{position:relative;width:100%}.comment-content-inner{overflow:hidden;position:relative;transition:max-height .4s cubic-bezier(.4,0,.2,1);white-space:pre-wrap;word-break:break-word}.expandable-comment.collapsed .comment-content-inner{mask-image:linear-gradient(180deg,#000 calc(100% - 60px),#0000);-webkit-mask-image:linear-gradient(180deg,#000 calc(100% - 60px),#0000)}.expand-trigger-wrapper{margin-top:10px;position:relative;text-align:center;z-index:2}.expand-btn{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#fff9;border:1px solid #e2e8f0;border-radius:20px;box-shadow:0 2px 4px #0000000d;color:#4a5568;cursor:pointer;display:inline-flex;font-size:.85rem;gap:4px;padding:6px 20px;transition:all .2s}.expand-btn:hover{background-color:#f7fafccc;border-color:#cbd5e0;box-shadow:0 4px 6px #00000014;color:#2d3748;transform:translateY(-1px)}.expand-btn:active{transform:translateY(0)}.expand-btn:after{border-left:4px solid #0000;border-right:4px solid #0000;border-top:5px solid;content:"";display:inline-block;height:0;transition:transform .3s ease;width:0}.expandable-comment.expanded .expand-btn:after{transform:rotate(180deg)}@media (max-width:768px){.expand-btn{font-size:.9rem;justify-content:center;padding:8px 24px;width:100%}.comment-content-inner{transition-duration:.5s}}.comment-section{animation:commentFadeIn .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-form{border:1px solid #ffffff4d}.comment-form,.comment-item{isolation:isolate}.comment-item:hover{border-color:#667eea4d}.comment-avatar img{border:2px solid #ffffff80}.comment-author{font-size:1rem}.top-badge{background-color:#f3e5f5b3;border:1px solid #e1bee7;color:#7b1fa2}.comment-location{align-items:center;backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background-color:#edf2f799;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 img[src*="/emoji/"]{border-radius:0;display:inline-block;height:32px;margin:0 2px;vertical-align:text-bottom;width:32px}.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-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;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#fffc;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 #ffffff80;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 commentFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@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}@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}}.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}.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:#ffffffe6;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:guestbookFadeIn .5s ease-out;margin:0 auto;max-width:900px;padding:2rem 0}.guestbook-header{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;isolation:isolate;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;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;backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);border:1px solid #0000;border-radius:12px;display:flex;gap:1rem;padding:1rem;text-decoration:none;transition:all .3s ease}.link-card:hover{background:#ffffffb3;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:#fffaf0b3;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,.top-badge{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter)}.comment-item.is-top{background:#fffaf0b3;border-left:4px solid #f6ad55}.message-board{border-top:none;margin-top:0;padding-top:0}.comment-form{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);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{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#f7fafc99;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:#ffffffd9;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}.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{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:var(--bg-card);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{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:#f8fafc99;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-body img[src*="/emoji/"],.comment-text img[src*="/emoji/"]{border-radius:0;display:inline-block;height:32px;margin:0 2px;vertical-align:text-bottom;width:32px}.comment-actions{display:flex;gap: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}.thread-toggle-btn{background:#667eea14;border:1px solid #667eea59;border-radius:999px;color:#4c51bf;font-size:.85rem;font-weight:700;padding:6px 12px;transition:transform .2s,box-shadow .2s,background-color .2s,border-color .2s}.thread-toggle-btn:hover{background:#667eea1f;border-color:#667eea99;box-shadow:0 8px 18px #667eea2e;transform:translateY(-1px)}.thread-toggle-btn.expanded{background:#764ba21a;border-color:#764ba259;color:#5a2ca0}.pagination{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:1.5rem}.page-btn{backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;border:1px solid #e2e8f0;border-radius:999px;box-shadow:0 2px 6px #0000000a;color:#4a5568;cursor:pointer;font-weight:700;padding:8px 14px;transition:transform .18s,box-shadow .18s,border-color .18s,background-color .18s,color .18s}.page-btn:hover:not(:disabled){border-color:#667eea80;box-shadow:0 10px 18px #667eea1f;color:#2d3748;transform:translateY(-1px)}.page-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.page-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 10px 22px #667eea47;color:#fff}.page-btn.nav{padding:8px 16px}.page-ellipsis{color:#a0aec0;font-weight:800;padding:0 4px}.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{color:#718096;padding:3rem}.loading-spinner{border:3px solid #e2e8f0}@keyframes guestbookFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@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}}.unicode-emoji{display:inline-block;font-size:32px!important;line-height:1;vertical-align:middle}: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:#fff9;--backdrop-filter:blur(12px);--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}html{scrollbar-gutter:stable}body,html{overflow-x:clip;width:100%}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}.app{display:flex;flex-direction:column;min-height:100vh}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes gradientBG{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.page-animate{animation:pageFadeIn .6s ease-out;will-change:transform}.slide-up-animate{animation:slideInUp .5s ease-out;will-change:transform}.slide-left-animate{animation:slideInLeft .5s ease-out;will-change:transform}.slide-right-animate{animation:slideInRight .5s ease-out;will-change:transform}.stagger-animate>*{animation:slideInUp .5s ease-out backwards}.stagger-animate>:first-child{animation-delay:.1s}.stagger-animate>:nth-child(2){animation-delay:.2s}.stagger-animate>:nth-child(3){animation-delay:.3s}.stagger-animate>:nth-child(4){animation-delay:.4s}.stagger-animate>:nth-child(5){animation-delay:.5s}.stagger-animate>:nth-child(6){animation-delay:.6s}.stagger-animate>:nth-child(7){animation-delay:.7s}.stagger-animate>:nth-child(8){animation-delay:.8s}.stagger-animate>:nth-child(9){animation-delay:.9s}.stagger-animate>:nth-child(10){animation-delay:1s}.header{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;background:var(--bg-card);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;background-clip:text;font-size:1.5rem;font-weight:800;letter-spacing:-.5px;text-decoration:none}.nav,.nav-content{align-items:center;display:flex}.nav-content{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}.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:160px}.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:160px}.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{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;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{align-items:center;display:flex;flex-wrap:wrap;font-size:1.35rem;font-weight:700;gap:.5rem;line-height:1.4;margin-bottom:1rem}.post-top-badge{align-items:center;background-color:#ff7e2114;border:1px solid #ff7e21;border-radius:20px;color:#ff7e21;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:500;line-height:1.2;padding:.15rem .6rem;white-space:nowrap}.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;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{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;background:var(--bg-card);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;padding-bottom:1.5rem}.archive-year-header{align-items:center;backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff6;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{display:grid;grid-template-rows:1fr;opacity:1;transition:grid-template-rows .5s cubic-bezier(.4,0,.2,1),opacity .5s ease}.archive-year-content.collapsed{grid-template-rows:0fr;opacity:0;pointer-events:none}.archive-year-inner{overflow:hidden}.archive-year-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800}.year-toggle{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff6;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));padding:4px 12px}.archive-card{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#ffffff80;border:1px solid #fff3;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:flex;flex-direction:column;height:100px;justify-content:space-between;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{flex:1 1;font-weight:700;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;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}.loading-container{align-items:center;background:#f7fafc;background:var(--bg-body);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #667eea33;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#718096;color:var(--text-secondary);font-size:1rem;font-weight:500}.page-loading{align-items:center;animation:pageFadeIn .3s ease-out;background:#0000;display:flex;justify-content:center;min-height:60vh}.main-content{background:#0000;flex:1 1;padding:3rem 0;position:relative}.loading{align-items:center;display:flex;font-size:1.2rem;justify-content:center;min-height:80vh;width:100%}.empty-desc,.loading{color:#718096;color:var(--text-secondary)}.empty-desc{margin-bottom:1.25rem}.empty-actions{align-items:center;display:inline-flex;gap:10px}.blog-header{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:1fr auto;margin-bottom:1.5rem}.blog-header .page-title{margin-bottom:0}.blog-search-bar{align-items:center;display:flex;gap:12px;max-width:600px;width:100%}.search-input-wrapper{align-items:center;backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;background:var(--bg-card);border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;flex:1 1;position:relative;transition:all .3s ease}.search-input-wrapper:focus-within{border-color:#a3bffa;box-shadow:0 10px 15px -3px #667eea1a,0 4px 6px -2px #667eea0d;transform:translateY(-1px)}.blog-search{background:#0000;border:none;border-radius:12px;color:#2d3748;color:var(--text-primary);font-size:1rem;font-weight:500;outline:none;padding:12px 40px 12px 16px;width:100%}.blog-search::placeholder{color:#a0aec0}.blog-clear-icon{align-items:center;animation:iconFadeIn .2s forwards;background:#edf2f7;border:none;border-radius:50%;color:#718096;cursor:pointer;display:flex;height:24px;justify-content:center;opacity:0;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:24px}@keyframes iconFadeIn{0%{opacity:0;transform:translateY(-50%) scale(.8)}to{opacity:1;transform:translateY(-50%) scale(1)}}.blog-clear-icon:hover{background:#cbd5e0;color:#4a5568}.blog-search-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;height:46px;justify-content:center;padding:0;transition:all .2s ease;white-space:nowrap;width:46px}.blog-search-btn:hover{box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.blog-search-btn:active{transform:translateY(0)}.blog-post{border:1px solid #00000008;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 2px 10px #00000008;display:flex;flex-direction:column;isolation:isolate;margin-bottom:2rem;padding:2.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);z-index:1}.blog-post:before{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;background:var(--bg-card);border-radius:16px;border-radius:var(--radius-lg);content:"";inset:0;position:absolute;z-index:-1}.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{backdrop-filter:blur(12px);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:blur(12px);-webkit-backdrop-filter:var(--backdrop-filter);background:#fff9;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);isolation:isolate;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;background-clip:text;font-size:2.25rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.post-meta{align-items:center;border-bottom:1px solid #edf2f7;color:#718096;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:.95rem;gap:1.5rem;margin-bottom:2rem;padding-bottom:1rem}.post-meta span{align-items:center;display:inline-flex}.tags{margin-bottom:2.5rem}.tag{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#edf2f799;border:1px solid #ffffff4d;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:#e2e8f0cc;border-color:#ffffff80;color:#2d3748}.post-body{word-wrap:break-word;color:#2d3748;font-size:1.05rem;line-height:1.8;overflow-wrap:break-word;word-break:break-word}.post-body table{border-collapse:collapse;display:block;margin:1.5rem 0;max-width:100%;overflow-x:auto;width:100%}.post-body iframe{max-width:100%}.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{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#f7fafc99;border:1px solid #fff3;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{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#2d3748e6;border:1px solid #ffffff1a;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}.post-body ol,.post-body ul{margin-bottom:1.6rem;padding-left:2rem}.post-body li{margin-bottom:.5rem}.code-block-wrapper{background:#1f2937;border-radius:12px;box-shadow:inset 0 2px 4px #00000014;margin:1.25rem 0;overflow:hidden;position:relative;transition:all .3s ease}.code-block-header{align-items:center;background:#111827;color:#e5e7eb;display:flex;font-size:.85rem;justify-content:space-between;padding:.5rem .75rem;position:relative;z-index:2}.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-container{overflow:hidden;position:relative;transition:max-height .5s cubic-bezier(.4,0,.2,1);will-change:max-height}.code-block-content{overflow-x:auto}.code-fade-overlay{background:linear-gradient(180deg,#1f293700,#1f2937);bottom:0;height:120px;left:0;pointer-events:none;position:absolute;right:0;transition:opacity .3s ease}.code-collapse-trigger{align-items:center;background:#2d3748;border-top:1px solid #ffffff0d;bottom:0;color:#e2e8f0;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:8px;justify-content:center;padding:10px 0;position:-webkit-sticky;position:sticky;text-align:center;transition:all .2s ease;width:100%;z-index:10}.code-collapse-trigger:hover{background:#374151;color:#fff}.code-collapse-trigger:focus{outline:none}.code-collapse-trigger svg{transition:transform .5s ease}.code-block-wrapper.collapsed .code-collapse-trigger{box-shadow:0 -4px 6px -1px #0000001a}.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;margin-top:auto;padding:25px 0;text-align:center}.footer,.footer p{color:#718096;color:var(--text-secondary)}.footer p{font-size:13px;margin:0}.footer a{color:#718096;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.footer a:hover{color:#667eea}.about-container{margin:0 auto;max-width:900px}.about-card{background:#fff9;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;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}.mobile-break{display:none}@media (max-width:768px){:root{--backdrop-filter:blur(8px)}.header,.nav,.post-card{transform:translateZ(0);will-change:transform,opacity}.mobile-break{display:block;margin-bottom:.2rem}.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%}}.mobile-menu-btn{background:#0000;border:none;cursor:pointer;display:none;padding:.5rem;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 cubic-bezier(.4,0,.2,1);transition:var(--transition);width:24px}.hamburger:after,.hamburger:before{content:"";left:0;position:absolute}.hamburger:before{top:-8px}.hamburger:after{bottom:-8px}.hamburger.active{background-color:initial}.hamburger.active:before{top:0;transform:rotate(45deg)}.hamburger.active:after{bottom:0;transform:rotate(-45deg)}@media (max-width:768px){.mobile-menu-btn{display:block}.nav{background:#fffffffa;border-radius:0 0 16px 16px;border-top:1px solid #0000000d;box-shadow:0 4px 6px -1px #0000000d;display:grid;grid-template-rows:0fr;height:auto;left:0;max-width:100%;opacity:0;overflow:hidden;padding:0;pointer-events:none;position:absolute;right:0;top:100%;transform:translateY(-8px);transition:grid-template-rows .35s cubic-bezier(.4,0,.2,1),opacity .3s ease,transform .35s cubic-bezier(.4,0,.2,1),visibility 0s linear .35s;visibility:hidden;width:100%;will-change:grid-template-rows,opacity,transform;z-index:-1}.nav.active{grid-template-rows:1fr;opacity:1;pointer-events:auto;transform:translateY(0);transition-delay:0s;visibility:visible;z-index:999}.nav-content{display:flex;flex-direction:column;gap:1rem;min-height:0;overflow:hidden;padding:1.5rem 2rem}.nav-link{border-radius:12px;font-size:1.1rem;padding:.8rem 1rem;text-align:center;width:100%}.nav-link.active,.nav-link:hover{background-color:#667eea1a}.blog-header{gap:1rem;grid-template-columns:1fr}.blog-search-bar{max-width:100%}.blog-header .page-title{margin-bottom:.5rem}.post-container{padding:1.5rem}.post-content h1{font-size:1.6rem;line-height:1.3;overflow-wrap:break-word;word-break:break-word}.hero h2{font-size:1.8rem}.subtitle{font-size:1rem}.page-title,.recent-posts h3{font-size:1.5rem;margin-bottom:1.5rem}.post-card h4{font-size:1.15rem}.blog-post h3{font-size:1.3rem}.post-body h2{font-size:1.35rem;margin-top:2rem}.post-body h3{font-size:1.2rem;margin-top:1.5rem}.about-section p,.blog-post p,.post-body p,.post-card p{font-size:.95rem;line-height:1.6}.about-header h2{font-size:1.8rem!important}.about-section h3{font-size:1.25rem}.blog-post p{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;margin-bottom:.8rem;overflow:hidden;text-overflow:ellipsis}}.api-status{font-size:.85rem;font-weight:500}.status{border-radius:50%;display:inline-block;height:8px;margin-right:6px;width:8px}.status.online{background-color:#48bb78;box-shadow:0 0 0 3px #48bb7833}.status.offline{background-color:#f56565;box-shadow:0 0 0 3px #f5656533}.replies-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s ease-out}.replies-wrapper.expanded{grid-template-rows:1fr}.replies-inner{overflow:hidden}.thread-toggle-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#667eea;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;padding:4px 8px;transition:all .2s}.thread-toggle-btn:hover{background:#667eea1a}.thread-toggle-btn.expanded{color:#718096}.thread-toggle-btn:before{border-left:4px solid #0000;border-right:4px solid #0000;border-top:5px solid;content:"";display:inline-block;height:0;margin-right:6px;transform:rotate(-90deg);transition:transform .5s;width:0}.thread-toggle-btn.expanded:before{transform:rotate(0deg)}
/*# sourceMappingURL=main.186a7ae3.css.map*/