﻿:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;max-width:100vw}body{background-color:var(--color-bg-primary);color:var(--color-text-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue","Noto Sans SC",sans-serif;line-height:1.6;font-size:1rem;background-image:none}.theme-transitioning,.theme-transitioning *,.theme-transitioning *::before,.theme-transitioning *::after{transition:background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease !important}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}button,input,textarea{font:inherit}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.container,.main-container{max-width:1200px;margin:0 auto;padding:1.5rem 1.5rem}.site-wrapper{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem 0}body{background-color:var(--color-bg-primary);color:var(--color-text-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue","Noto Sans SC",sans-serif;font-size:1rem;line-height:1.6;transition:background-color 0.3s ease, color 0.3s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,.page-title{font-size:2rem;margin-bottom:1.5rem;font-weight:700;line-height:1.2;letter-spacing:-0.02em}h2,.section-title{font-size:1.8rem;margin:2rem 0 1rem;font-weight:600;letter-spacing:-0.01em}h3{font-size:1.3rem;margin:1.5rem 0 .5rem;font-weight:600}h4{font-size:1.1rem;margin:1rem 0 .5rem;font-weight:600}a{color:var(--color-link);text-decoration:none;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}a:hover{color:var(--color-link-hover)}.site-footer{text-align:center;padding:3rem 0;border-top:1px solid var(--color-border);margin-top:3rem;color:var(--color-text-tertiary);font-size:.9rem}p{margin-bottom:1.5rem;line-height:1.75}ul,ol{margin-bottom:1.5rem;padding-left:2rem}@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes scaleIn{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}.toast-container{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:1000;display:flex;flex-direction:column;gap:0.75rem}.toast-message{background:var(--color-surface);color:var(--color-text-primary);padding:0.9rem 1.25rem;border-radius:1rem;box-shadow:0 8px 24px rgba(0,0,0,0.15);display:flex;align-items:center;gap:0.75rem;min-width:280px;max-width:420px;border:1px solid var(--color-border)}.toast-message span{flex:1;font-size:0.95rem;line-height:1.4}.toast-message .close-toast{background:transparent;border:none;cursor:pointer;color:var(--color-text-tertiary);padding:0.25rem;border-radius:0.5rem;display:flex;align-items:center;justify-content:center;transition:all 0.2s ease}.toast-message .close-toast:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.toast-message.fade-out{opacity:0;transform:translateY(8px);transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background 0.3s ease}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}::selection{background:rgba(200,162,122,0.3);color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.site-header{background:rgba(250,250,248,0.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,0.08);position:sticky;top:0;z-index:1000;transition:all 0.3s ease}[data-theme="dark"] .site-header{background:rgba(26,24,22,0.9);border-bottom:1px solid rgba(255,255,255,0.08)}.nav-container{max-width:1200px;margin:0 auto;padding:0.85rem 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.logo a{font-weight:700;font-size:1.15rem;color:var(--color-text-primary);text-decoration:none;transition:all 0.2s ease}.logo a:hover{color:var(--color-link);transform:translateY(-1px)}.nav-menu{display:flex;gap:0.5rem;list-style:none;margin:0;padding:0;align-items:center}.nav-menu li{transition:all 0.2s ease}.nav-menu .nav-link{color:var(--color-text-primary);padding:0.5rem 0.9rem;font-size:0.95rem;font-weight:500;transition:all 0.2s ease;border-radius:8px;text-decoration:none;position:relative}.nav-menu .nav-link::after{content:'';position:absolute;bottom:0.25rem;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--color-primary);border-radius:2px;transition:width 0.2s ease}.nav-menu .nav-link:hover{color:var(--color-link);background:var(--color-bg-secondary)}.nav-menu .nav-link:hover::after{width:40%}.nav-menu .nav-link.active{color:var(--color-link);background:rgba(200,162,122,0.1)}.nav-menu .nav-link.active::after{width:40%}.social-buttons{display:flex;gap:0.5rem;margin-left:0.25rem}.icon-buttons-row{display:flex;gap:0.5rem;margin-left:0.25rem}.social-btn{width:2.4rem;height:2.4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all 0.2s ease;background:var(--color-bg-secondary);text-decoration:none;border:1px solid var(--color-border)}.social-btn:hover{background:var(--color-bg-card);color:var(--color-link);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.08);border-color:var(--color-primary)}.icon-btn{width:2.6rem;height:2.6rem;border-radius:50%;background:var(--color-bg-secondary);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;transition:all 0.2s ease;cursor:pointer;color:var(--color-text-primary);position:relative;overflow:hidden}.icon-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.08);border-color:var(--color-border)}.icon-btn:active{transform:translateY(0) scale(0.98)}.icon-btn svg{transition:all 0.2s ease}.icon-btn .icon-moon{position:absolute;opacity:0;transform:rotate(-90deg) scale(0.5)}.icon-btn .icon-sun{opacity:1;transform:rotate(0) scale(1)}[data-theme="dark"] .icon-btn{border-color:rgba(255,255,255,0.08)}[data-theme="dark"] .icon-btn .icon-sun{opacity:0;transform:rotate(90deg) scale(0.5)}[data-theme="dark"] .icon-btn .icon-moon{opacity:1;transform:rotate(0) scale(1)}.menu-toggle{display:none;background:var(--color-bg-secondary);border:1px solid var(--color-border);width:2.6rem;height:2.6rem;border-radius:50%;align-items:center;justify-content:center;font-size:1.25rem;cursor:pointer;color:var(--color-text-primary);transition:all 0.2s ease;position:relative;z-index:999}.menu-toggle .icon-menu,.menu-toggle .icon-close{position:absolute;transition:opacity 0.3s ease, transform 0.3s ease}.menu-toggle .icon-close{opacity:0;transform:rotate(90deg) scale(0.8)}.menu-toggle.active .icon-menu{opacity:0;transform:rotate(-90deg) scale(0.8)}.menu-toggle.active .icon-close{opacity:1;transform:rotate(0) scale(1)}.menu-toggle:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.08)}.search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(250,250,248,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;z-index:10000;opacity:0;visibility:hidden;transition:opacity 0.3s ease, visibility 0.3s ease}[data-theme="dark"] .search-overlay{background:rgba(26,24,22,0.95)}.search-overlay.active{opacity:1;visibility:visible}.search-container{width:100%;max-width:640px;max-height:70vh;background:var(--color-surface);border-radius:20px;padding:0;box-shadow:0 24px 48px rgba(0,0,0,0.12),0 0 0 1px var(--color-border);position:relative;transform:translateY(-20px) scale(0.96);transition:transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),opacity 0.3s ease;opacity:0;margin:0 1rem;display:flex;flex-direction:column;overflow:hidden}[data-theme="dark"] .search-container{box-shadow:0 24px 48px rgba(0,0,0,0.4),0 0 0 1px var(--color-border)}.search-overlay.active .search-container{transform:translateY(0) scale(1);opacity:1}.search-input-wrapper{position:relative;width:100%;display:flex;align-items:center;padding:0.75rem 0.75rem 0.75rem 1.25rem;border-bottom:1px solid var(--color-border)}.search-icon{width:20px;height:20px;color:var(--color-text-tertiary);flex-shrink:0;margin-right:0.75rem}.search-input{flex:1;padding:0.75rem 0;font-size:1.05rem;border:none;outline:none;background:transparent;color:var(--color-text-primary);transition:all 0.2s ease}.search-input::placeholder{color:var(--color-text-tertiary)}.search-close{background:var(--color-bg-secondary);border:1px solid var(--color-border);width:2rem;height:2rem;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-secondary);transition:all 0.2s ease;flex-shrink:0}.search-close:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:rotate(90deg)}.search-results{padding:0.5rem;max-height:55vh;overflow-y:auto;flex:1;min-height:0}.search-result-item{padding:0.85rem 1rem;border-radius:12px;margin-bottom:0.25rem;cursor:pointer;transition:all 0.2s ease;border:1px solid transparent;text-decoration:none;display:block}.search-result-item:hover{background:var(--color-bg-secondary);border-color:var(--color-border);transform:translateX(4px)}.search-result-title{font-size:0.95rem;font-weight:600;color:var(--color-link);margin-bottom:0.25rem}.search-result-date{font-size:0.75rem;color:var(--color-text-tertiary)}.search-result-summary{font-size:0.85rem;color:var(--color-text-secondary);margin-top:0.25rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-result-empty{text-align:center;padding:2.5rem 1rem;color:var(--color-text-tertiary);font-size:0.95rem}.search-hint{text-align:center;padding:2rem 1rem;color:var(--color-text-tertiary);font-size:0.9rem}@media (max-width: 768px){.nav-container{position:relative}.nav-menu{display:none}.nav-menu.mobile-fullscreen{display:flex;position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;max-height:100vh;margin:0;padding:7rem 1.5rem 2rem;background:var(--color-bg-primary);border:none;border-radius:0;z-index:998;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:0;opacity:0;visibility:hidden;transform:translateY(-20px);transition:opacity 0.35s ease, visibility 0.35s ease, transform 0.35s ease, background-color 0.3s ease;overflow-y:auto}.nav-menu.mobile-fullscreen.active{opacity:1;visibility:visible;transform:translateY(0)}.nav-menu.mobile-fullscreen li{width:100%;max-width:320px;opacity:0;transform:translateY(15px);transition:opacity 0.3s ease, transform 0.3s ease}.nav-menu.mobile-fullscreen.active li{opacity:1;transform:translateY(0)}.nav-menu.mobile-fullscreen.active li:nth-child(1){transition-delay:0.05s}.nav-menu.mobile-fullscreen.active li:nth-child(2){transition-delay:0.1s}.nav-menu.mobile-fullscreen.active li:nth-child(3){transition-delay:0.15s}.nav-menu.mobile-fullscreen.active li:nth-child(4){transition-delay:0.2s}.nav-menu.mobile-fullscreen.active li:nth-child(5){transition-delay:0.25s}.nav-menu.mobile-fullscreen.active li:nth-child(6){transition-delay:0.3s}.nav-menu.mobile-fullscreen.active li:nth-child(7){transition-delay:0.35s}.nav-menu.mobile-fullscreen.active li:nth-child(8){transition-delay:0.4s}.nav-menu .nav-link{display:block;padding:0.85rem 1rem;width:100%;text-align:left;border-radius:8px;font-size:1.1rem}.nav-menu.mobile-fullscreen .icon-buttons-row{display:flex;align-items:center;gap:0.75rem;padding:0.75rem 0;width:100%;max-width:320px;margin-left:0}.nav-menu.mobile-fullscreen .icon-buttons-row .icon-btn{width:2.8rem;height:2.8rem;flex-shrink:0}.nav-menu.mobile-fullscreen .social-buttons{justify-content:flex-start;padding:0;gap:0.75rem;width:100%;max-width:320px;margin-left:0}.nav-menu.mobile-fullscreen .social-btn{width:2.8rem;height:2.8rem}.nav-menu.mobile-fullscreen .search-toggle-item,.nav-menu.mobile-fullscreen .theme-toggle-item{width:auto;max-width:none;display:none}.menu-toggle{display:flex;background:var(--color-bg-secondary);border:1px solid var(--color-border);width:2.6rem;height:2.6rem;border-radius:50%;align-items:center;justify-content:center;font-size:1.25rem;cursor:pointer;color:var(--color-text-primary);transition:all 0.2s ease;position:relative;z-index:999}.menu-toggle:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.menu-toggle.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.logo.mobile-hidden{opacity:0;visibility:hidden;transition:opacity 0.2s ease, visibility 0.2s ease}.search-container{max-height:90vh;margin:0.5rem;border-radius:16px}.search-results{max-height:60vh}}@media (min-width: 769px){.menu-toggle{display:none}}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.home-page{padding:3rem 0}.intro-section{margin-bottom:3rem}.intro-avatar{margin-bottom:2rem}.intro-avatar .avatar-img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--color-bg-card);box-shadow:var(--shadow-sm)}.intro-header{margin-bottom:1.5rem}.intro-title{font-size:1.8rem;font-weight:600;margin-bottom:.5rem;color:var(--color-text-primary);letter-spacing:-0.02em;line-height:1.2}.intro-subtitle{font-size:1rem;color:var(--color-text-tertiary);margin:0}.intro-content{color:var(--color-text-secondary);line-height:1.6}.intro-content p{margin-bottom:0.8rem;font-size:1rem}.intro-content .section-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:1.2rem 0 0.6rem 0}.category-nav{display:grid;grid-template-columns:repeat(4, 1fr);gap:1.5rem;margin-bottom:3rem}@media (max-width: 768px){.category-nav{grid-template-columns:repeat(2, 1fr)}}@media (max-width: 480px){.category-nav{grid-template-columns:1fr}}.category-item{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background-color:var(--color-bg-card);border-radius:.5rem;border:1px solid var(--color-border);transition:all 0.25s ease;text-decoration:none;color:var(--color-text-primary)}.category-item:hover{background-color:var(--color-bg-hover);transform:translateY(-2px);border-color:var(--color-primary);box-shadow:var(--shadow-hover)}.category-item .category-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--color-primary);background:var(--color-bg-accent);border-radius:.25rem}.category-item .category-count{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin-bottom:2px}.category-item .category-name{font-size:0.875rem;color:var(--color-text-secondary)}.social-links{margin-bottom:3rem}.social-links .social-grid{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}.social-links .social-item{display:flex;align-items:center;gap:0.5rem;padding:0.6rem 1rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:.5rem;color:var(--color-text-secondary);text-decoration:none;font-size:0.875rem;transition:all 0.2s ease}.social-links .social-item:hover{background:var(--color-bg-hover);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.latest-posts{margin-bottom:3rem}.latest-posts .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.latest-posts .section-header .section-title{font-size:1.25rem;font-weight:600;margin:0;position:relative}.latest-posts .section-header .section-title::after{content:'';position:absolute;bottom:-8px;left:0;width:30px;height:2px;background:var(--color-primary);border-radius:2px}.latest-posts .section-header .view-all{font-size:0.9rem;color:var(--color-link);text-decoration:none;transition:all 200ms ease-in-out;padding:0.5rem 1rem;border-radius:4px;background:var(--color-bg-card);border:1px solid var(--color-border)}.latest-posts .section-header .view-all:hover{color:var(--color-link-hover);text-decoration:underline}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:1.5rem}.post-card{background-color:var(--color-bg-card);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all 200ms ease-in-out;height:100%;position:relative}.post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:var(--color-primary)}.post-card__content{display:flex;flex-direction:column;height:100%}.post-card__title{font-size:1.1rem;font-weight:600;margin-bottom:1rem;line-height:1.3}.post-card__title a{color:var(--color-text-primary);text-decoration:none;transition:all 200ms ease-in-out}.post-card__title a:hover{color:var(--color-link);text-decoration:underline}.post-card__summary{color:var(--color-text-secondary);font-size:0.95rem;line-height:1.6;margin-bottom:1.5rem;flex:1}.post-card__meta{display:flex;justify-content:space-between;align-items:center;font-size:0.85rem;color:var(--color-text-tertiary);border-top:1px solid var(--color-border);padding-top:1rem;margin-top:auto}.post-card__meta time{flex-shrink:0}.post-card__meta .tag-list{margin:0;gap:0.35rem}.post-card__meta .tag{display:inline-block;padding:0.25rem 0.5rem;background:var(--color-bg-accent);color:var(--color-primary);font-size:0.75rem;border-radius:4px}.photo-wall-section{margin:3rem 0;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);width:100vw;position:relative;overflow:hidden;z-index:1}.photo-wall{width:100%;height:100vh;min-height:500px;max-height:900px;position:sticky;top:0;overflow:hidden;background:var(--color-bg-secondary)}.photo-wall::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.4) 100%);pointer-events:none;z-index:10}.photo-track{position:absolute;top:0;left:0;margin:0;padding:0}.photo-item{overflow:hidden;position:absolute !important;border:none !important;margin:0 !important;padding:0 !important;transform:none !important}.photo-item img{width:100%;height:100%;object-fit:contain;display:block;margin:0;padding:0}@media (max-width: 768px){.photo-wall{height:60vh;min-height:400px}.photo-wall-section{margin-left:0;margin-right:0;width:100%}}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.post-card{background:var(--color-bg-card);border-radius:.75rem;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,0.04);transition:all 200ms ease-in-out;margin-bottom:2rem;display:flex;flex-direction:column;padding:1.5rem}.post-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.08)}.post-card__image-link{display:block;line-height:0}.post-card__image{width:100%;height:240px;object-fit:cover;display:block}.post-card__content{padding:1rem 0}.post-card__title{font-size:1.3rem;margin-bottom:.5rem}.post-card__title a{color:var(--color-text-primary)}.post-card__title a:hover{color:var(--color-link-hover)}.post-card__summary{color:var(--color-text-secondary);font-size:1rem;margin-bottom:1rem}.post-card__meta{font-size:.9rem;color:var(--color-text-tertiary);border-top:1px solid var(--color-border);padding-top:1rem;margin-top:1rem}.posts-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 640px){.posts-grid{grid-template-columns:repeat(2, 1fr)}}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.article-page{padding:3rem 0}.article-layout{display:grid;grid-template-columns:220px 1fr;gap:3rem;max-width:1100px;margin:0 auto}@media (max-width: 900px){.article-layout{grid-template-columns:1fr}}.article-toc{position:sticky;top:100px;height:fit-content;max-height:calc(100vh - 120px);overflow-y:auto;padding:1rem;background:var(--color-bg-card);border-radius:1rem;border:1px solid var(--color-border);font-size:.9rem}@media (max-width: 900px){.article-toc{display:none}}.article-toc .toc-header{display:flex;align-items:center;gap:0.5rem;font-weight:600;color:var(--color-text-primary);margin-bottom:0.75rem;padding-bottom:0.5rem;border-bottom:1px solid var(--color-border)}.article-toc #TableOfContents ul{list-style:none;padding:0;margin:0}.article-toc #TableOfContents ul ul{padding-left:1rem;margin-top:0.25rem}.article-toc #TableOfContents ul li{margin-bottom:0.35rem}.article-toc #TableOfContents ul a{color:var(--color-text-secondary);text-decoration:none;transition:all 0.2s ease;display:block;padding:0.25rem 0.5rem;border-radius:0.35rem;line-height:1.4}.article-toc #TableOfContents ul a:hover{color:var(--color-link);background:var(--color-bg-secondary)}.article-standalone{min-width:0}.article-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}.article-title{font-size:2.25rem;font-weight:700;margin-bottom:1.5rem;line-height:1.25;letter-spacing:-0.02em;color:var(--color-text-primary)}.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:0.75rem;font-size:.9rem;color:var(--color-text-tertiary)}.article-meta time{display:inline-flex;align-items:center;gap:0.4rem}.article-meta .meta-divider{width:4px;height:4px;background:var(--color-text-tertiary);border-radius:50%}.article-meta .category-tag{background:var(--color-bg-secondary);padding:0.2rem 0.6rem;border-radius:0.5rem;font-size:.8rem;color:var(--color-text-secondary)}.article-meta .tag{background:var(--color-bg-secondary);color:var(--color-text-secondary);padding:0.2rem 0.6rem;border-radius:0.5rem;font-size:.8rem}.article-body{line-height:1.8;font-size:1.05rem;color:var(--color-text-primary)}.article-body h1,.article-body h2,.article-body h3,.article-body h4,.article-body h5,.article-body h6{margin-top:3rem;margin-bottom:1.5rem;line-height:1.3;font-weight:600;color:var(--color-text-primary);letter-spacing:-0.01em}.article-body h1{font-size:1.875rem}.article-body h2{font-size:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.article-body h3{font-size:1.25rem}.article-body h4{font-size:1.1rem}.article-body p{margin-bottom:1.5rem}.article-body a{color:var(--color-link);text-decoration:none;border-bottom:1px solid rgba(200,162,122,0.4);padding-bottom:1px;transition:all 0.3s ease}.article-body a:hover{color:var(--color-link-hover);border-bottom-color:var(--color-link-hover)}.article-body strong{font-weight:600}.article-body em{font-style:italic}.article-body blockquote{border-left:3px solid var(--color-primary);padding:1.5rem 2rem;margin:2rem 0;background:var(--color-tip-bg);border-radius:0 .5rem .5rem 0;color:var(--color-text-secondary);font-style:italic}.article-body blockquote p:last-child{margin-bottom:0}.article-body .highlight{position:relative;margin:2rem 0;border-radius:.5rem;overflow:hidden;border:1px solid var(--color-border)}.article-body .highlight .code-lang{position:absolute;top:0.6rem;right:0.8rem;font-size:0.7rem;font-weight:600;text-transform:uppercase;color:var(--color-text-tertiary);background:var(--color-bg-secondary);padding:0.15rem 0.5rem;border-radius:4px;letter-spacing:0.05em;z-index:1;pointer-events:none}.article-body .highlight pre{margin:0;border:none;border-radius:0;padding-top:2rem}.article-body pre{background:var(--color-bg-code);border-radius:.5rem;padding:1.5rem 1.75rem 1.5rem 2rem;overflow-x:auto;margin:2rem 0;font-size:.9rem;line-height:1.7;border:1px solid var(--color-border);position:relative;box-sizing:border-box}.article-body pre code{background:none;padding:0;font-size:inherit;border:none;color:inherit}.article-body code{background:var(--color-bg-code);padding:0.15rem 0.4rem;border-radius:.25rem;font-size:0.9em;color:var(--color-link);border:1px solid var(--color-border)}.article-body ul,.article-body ol{margin:1.5rem 0;padding-left:2rem}.article-body ul li,.article-body ol li{margin-bottom:.5rem;line-height:1.7}.article-body ul li::marker{color:var(--color-primary)}.article-body ol li::marker{color:var(--color-text-secondary);font-weight:500}.article-body hr{border:none;height:1px;background:var(--color-border);margin:4rem 0}.article-body img{max-width:100%;height:auto;border-radius:.5rem;margin:2rem 0;box-shadow:0 4px 16px rgba(0,0,0,0.08)}.article-body .table-wrapper{overflow-x:auto;margin:2rem 0;border-radius:.5rem;border:1px solid var(--color-border)}.article-body table{width:100%;border-collapse:collapse;margin:0;font-size:.9rem}.article-body table th,.article-body table td{padding:1rem 1.5rem;border:1px solid var(--color-border);text-align:left}.article-body table th{background:var(--color-bg-secondary);font-weight:600}.article-body table tr:hover td{background:var(--color-bg-secondary)}.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:4rem;padding-top:3rem;border-top:1px solid var(--color-border)}@media (max-width: 640px){.article-nav{grid-template-columns:1fr;gap:1.5rem}}.article-nav>div{padding:1.5rem 0;transition:all 0.3s ease}.article-nav .nav-label{display:inline-flex;align-items:center;gap:0.35rem;font-size:.8rem;color:var(--color-text-tertiary);margin-bottom:0.35rem;text-transform:uppercase;letter-spacing:0.05em}.article-nav a{font-size:1rem;font-weight:500;color:var(--color-link);text-decoration:none;transition:color 0.3s ease;display:block;line-height:1.4}.article-nav a:hover{color:var(--color-link-hover)}.article-nav .nav-prev{grid-column:1}.article-nav .nav-next{grid-column:2;text-align:right}@media (max-width: 640px){.article-nav .nav-next{grid-column:1;text-align:left}}.back-to-top{position:fixed;bottom:3rem;right:3rem;width:48px;height:48px;border-radius:50%;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:all 0.35s cubic-bezier(0.4, 0, 0.2, 1);box-shadow:0 4px 16px rgba(0,0,0,0.08);z-index:90}.back-to-top:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.15)}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.blog-page{padding:2rem 0}.page-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}.page-header .page-title{font-size:2rem;font-weight:700;margin-bottom:1rem;letter-spacing:-0.02em}.page-header .page-description{color:var(--color-text-secondary);font-size:1.1rem;line-height:1.6}.blog-layout{display:grid;grid-template-columns:240px 1fr;gap:3rem}@media (max-width: 900px){.blog-layout{grid-template-columns:1fr}}@media (max-width: 900px){.blog-sidebar{display:none}}.sidebar-section{margin-bottom:3rem}.sidebar-section .sidebar-title{font-size:.9rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:1.5rem}.tag-filter{display:flex;flex-direction:column;gap:0.5rem}.tag-filter .tag{display:flex;align-items:center;padding:0.5rem 0.85rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:0.75rem;font-size:.9rem;color:var(--color-text-secondary);cursor:pointer;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}.tag-filter .tag:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateX(4px)}.tag-filter .tag.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.contact-section .contact-links{display:flex;flex-direction:column;gap:0.5rem}.contact-link{display:flex;align-items:center;gap:0.75rem;padding:0.6rem 0.85rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:0.75rem;font-size:.9rem;color:var(--color-text-secondary);text-decoration:none;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}.contact-link svg{flex-shrink:0;opacity:0.7;transition:opacity 0.3s ease}.contact-link span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.contact-link:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateX(4px)}.contact-link:hover svg{opacity:1}.blog-main{min-width:0}.posts-timeline{position:relative;padding-left:2rem}.posts-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom, transparent 0%, var(--color-border) 5%, var(--color-border) 95%, transparent 100%)}.timeline-item{position:relative;margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border);transition:all 0.3s ease;cursor:pointer}.timeline-item:last-child{border-bottom:none;margin-bottom:0}.timeline-item:hover .timeline-marker{background:var(--color-primary);transform:scale(1.3);box-shadow:0 0 0 4px rgba(200,162,122,0.2)}.timeline-item:hover .timeline-content{transform:translateX(6px)}.timeline-item:hover .timeline-title a{color:var(--color-link)}.timeline-item .timeline-marker{position:absolute;left:-2rem;top:0.35rem;width:12px;height:12px;background:var(--color-text-tertiary);border-radius:50%;border:2px solid var(--color-bg-primary);transition:all 0.35s cubic-bezier(0.4, 0, 0.2, 1)}.timeline-item .timeline-content{transition:transform 0.3s cubic-bezier(0.4, 0, 0.2, 1)}.timeline-item .timeline-header{display:flex;align-items:center;flex-wrap:wrap;gap:0.75rem;margin-bottom:.5rem}.timeline-item .timeline-date{font-size:.9rem;color:var(--color-text-tertiary);font-weight:500}.timeline-item .tag-list{display:flex;flex-wrap:wrap;gap:0.35rem}.timeline-item .tag-list .tag{font-size:0.7rem;padding:0.15rem 0.5rem}.timeline-item .timeline-title{font-size:1.15rem;font-weight:600;margin-bottom:.5rem;line-height:1.35}.timeline-item .timeline-title a{color:var(--color-text-primary);text-decoration:none;transition:color 0.3s ease}.timeline-item .timeline-summary{color:var(--color-text-secondary);font-size:.9rem;line-height:1.7;margin:0}.timeline-item.hidden{display:none}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.prompt{padding:1rem 1.5rem;border-radius:.5rem;border-left:4px solid;margin:1.5rem 0;font-size:1rem;line-height:1.6}.prompt p:last-child{margin-bottom:0}.prompt-tip{background-color:var(--color-tip-bg);border-color:var(--color-link);color:var(--color-text-primary)}.prompt-tip::before{content:"💡 "}.prompt-info{background-color:var(--color-info-bg);border-color:#7BAFD4;color:var(--color-text-primary)}.prompt-info::before{content:"ℹ️ "}.prompt-success{background-color:var(--color-success-bg);border-color:#7AC4A0;color:var(--color-text-primary)}.prompt-success::before{content:"✅ "}.prompt-warning{background-color:var(--color-warning-bg);border-color:#E8B86D;color:var(--color-text-primary)}.prompt-warning::before{content:"⚠️ "}.prompt-error{background-color:var(--color-error-bg);border-color:#D48080;color:var(--color-text-primary)}.prompt-error::before{content:"❌ "}details.prompt-details{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:.5rem;margin:1.5rem 0;overflow:hidden}details.prompt-details summary{padding:1rem 1.5rem;cursor:pointer;font-weight:500;color:var(--color-text-primary);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);transition:all 150ms ease-in-out;display:flex;align-items:center;gap:0.5rem;user-select:none}details.prompt-details summary::before{content:"▶";font-size:0.75rem;transition:transform 150ms ease-in-out}details.prompt-details summary:hover{background:var(--color-bg-hover)}details.prompt-details summary::-webkit-details-marker{display:none}details.prompt-details[open] summary{border-bottom:1px solid var(--color-border)}details.prompt-details[open] summary::before{transform:rotate(90deg)}details.prompt-details .prompt-details-content{padding:1.5rem;color:var(--color-text-secondary);line-height:1.6}details.prompt-details .prompt-details-content>*:last-child{margin-bottom:0}.badge{display:inline-flex;align-items:center;padding:0.2rem 0.6rem;font-size:0.75rem;font-weight:500;border-radius:.25rem;background:#E4D2BC;color:#383430;vertical-align:middle;line-height:1.4}.badge-primary{background:rgba(200,162,122,0.15);color:#B0885C}.badge-info{background:rgba(123,175,212,0.15);color:#5A8FAD}.badge-success{background:rgba(122,196,160,0.15);color:#5A9A7A}.badge-warning{background:rgba(232,184,109,0.15);color:#B08840}.badge-error{background:rgba(212,128,128,0.15);color:#B06060}.badge-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}[data-theme="dark"] .badge{background:#3D3832;color:#D9D4CE}[data-theme="dark"] .badge-primary{background:rgba(200,162,122,0.2);color:#D9B992}[data-theme="dark"] .badge-info{background:rgba(123,175,212,0.2);color:#9DC4DD}[data-theme="dark"] .badge-success{background:rgba(122,196,160,0.2);color:#9DD4B5}[data-theme="dark"] .badge-warning{background:rgba(232,184,109,0.2);color:#E8C890}[data-theme="dark"] .badge-error{background:rgba(212,128,128,0.2);color:#E4A0A0}[data-theme="dark"] .badge-outline{border-color:rgba(255,255,255,0.15);color:var(--color-text-secondary)}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.blockquote-float-left{float:left;max-width:45%;margin:0 2rem 1.5rem 0;padding:1.5rem 2rem;background:var(--color-tip-bg);border-left:3px solid var(--color-primary);border-radius:0 .5rem .5rem 0;font-style:italic;color:var(--color-text-secondary)}.blockquote-float-right{float:right;max-width:45%;margin:0 0 1.5rem 2rem;padding:1.5rem 2rem;background:var(--color-tip-bg);border-left:3px solid var(--color-primary);border-radius:0 .5rem .5rem 0;font-style:italic;color:var(--color-text-secondary)}.article-body :not(pre)>code{background:var(--color-bg-code);padding:0.15rem 0.4rem;border-radius:.25rem;font-size:0.9em;color:var(--color-link);border:1px solid var(--color-border)}.article-body pre{background:var(--color-bg-code);border-radius:.5rem;padding:1.5rem 1.75rem;overflow-x:auto;margin:2rem 0;font-size:.9rem;line-height:1.7;border:1px solid var(--color-border);position:relative}.article-body pre.chroma{position:relative}.article-body pre.chroma .code-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--color-border);font-size:0.75rem;color:var(--color-text-tertiary)}.article-body pre code{background:none;padding:0;font-size:inherit;border:none;color:inherit}.article-body .highlight pre{margin:0;padding:0;border:none;background:transparent}.article-body .line-numbers{counter-reset:line}.article-body .line-numbers .line{counter-increment:line;display:block}.article-body .line-numbers .line::before{content:counter(line);margin-right:1.5rem;color:var(--color-text-muted);font-size:0.85em}.footnotes{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--color-border);font-size:.9rem;color:var(--color-text-secondary)}.footnotes hr{display:none}.footnotes ol{padding-left:2rem}.footnotes ol li{margin-bottom:.5rem;line-height:1.6}.footnotes p{margin-bottom:.5rem}.footnotes a{color:var(--color-link);text-decoration:none}.footnotes a:hover{text-decoration:underline}.task-list{list-style:none;padding-left:0}.task-list li{display:flex;align-items:flex-start;gap:0.5rem;margin-bottom:0.5rem}.task-list li input[type="checkbox"]{margin-top:0.35rem;accent-color:var(--color-primary);cursor:pointer}.task-list li.done{color:var(--color-text-muted);text-decoration:line-through}.clearfix::after{content:"";display:table;clear:both}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.tag{display:inline-flex;align-items:center;padding:0.25rem 0.75rem;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);border-radius:.25rem;font-size:.8rem;transition:all 150ms ease-in-out;text-decoration:none}.tag:hover{background-color:var(--color-primary);color:#ffffff;transform:translateY(-1px)}.tag.active{background-color:var(--color-primary);color:#ffffff}.tag-filter{margin:1.5rem 0;padding:1rem;background-color:var(--color-bg-secondary);border-radius:.5rem}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}#nprogress{pointer-events:none;z-index:9999}#nprogress .bar{background:linear-gradient(90deg, var(--color-primary) 0%, var(--color-link) 100%);position:fixed;z-index:9999;top:0;left:0;width:100%;height:3px;transition:width 0.3s ease-out, opacity 0.3s ease;box-shadow:0 0 10px rgba(var(--color-primary-rgb, 212, 165, 116), 0.5)}#nprogress .peg{display:block;position:absolute;right:0px;width:100px;height:100%;opacity:0}#nprogress .spinner{display:none}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.toast-container{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:1050;pointer-events:none}.toast-container .toast-message{background-color:var(--color-surface);color:var(--color-text-primary);padding:1rem 1.5rem;border-radius:.5rem;box-shadow:0 4px 12px rgba(0,0,0,0.1);font-size:.9rem;border:1px solid var(--color-border);pointer-events:auto;backdrop-filter:none;display:flex;align-items:center;gap:1rem;animation:fadeInUp 0.3s ease}.toast-container .toast-message .close-toast{cursor:pointer;margin-left:1rem;font-weight:bold;color:var(--color-text-secondary)}.toast-container .toast-message .close-toast:hover{color:var(--color-primary)}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}:root{--color-bg-primary: #FAFAF8;--color-bg-secondary: #F5F5F3;--color-bg-card: #FFFFFF;--color-bg-code: #F3F3F0;--color-bg-hover: #F5F5F3;--color-border: rgba(0,0,0,0.08);--color-text-primary: #1A1A18;--color-text-secondary: #3D3D3A;--color-text-tertiary: #6B6B66;--color-text-muted: #9A9A94;--color-link: #B88A62;--color-link-hover: #9A7050;--color-primary: #B88A62;--color-primary-light: #D4A574;--color-surface: #FFFFFF;--color-tip-bg: #F8F6F2;--color-tip-border: #E8E4DC;--color-info-bg: #EDF4F8;--color-info-border: #7BAFD4;--color-success-bg: #EAF5EE;--color-success-border: #7AC4A0;--color-warning-bg: #FFF9E6;--color-warning-border: #E8B86D;--color-error-bg: #FDEEEE;--color-error-border: #D48080}[data-theme="dark"]{--color-bg-primary: #1A1816;--color-bg-secondary: #252320;--color-bg-card: #252320;--color-bg-code: #2E2B28;--color-bg-hover: #2E2B28;--color-border: rgba(255,255,255,0.12);--color-text-primary: #F2EDE8;--color-text-secondary: #D9D4CE;--color-text-tertiary: #B0ABA4;--color-text-muted: #8A857E;--color-link: #C8A27A;--color-link-hover: #D9B992;--color-primary: #C8A27A;--color-primary-light: #D9B992;--color-surface: #252320;--color-tip-bg: #2E2B28;--color-tip-border: #4A4540;--color-info-bg: #252B32;--color-info-border: #5A7A94;--color-success-bg: #252E28;--color-success-border: #5A8A6A;--color-warning-bg: #2E2B25;--color-warning-border: #6A5A30;--color-error-bg: #2E2525;--color-error-border: #6A4040}[data-theme="dark"] body{background-image:radial-gradient(rgba(200,162,122,0.03) 1px, transparent 1px);background-size:20px 20px}.breadcrumb{display:flex;align-items:center;gap:0.5rem;font-size:0.9rem;color:var(--color-text-tertiary);margin-bottom:1.5rem;padding-top:1.5rem}.breadcrumb a{color:var(--color-text-tertiary);text-decoration:none;transition:color 0.2s ease}.breadcrumb a:hover{color:var(--color-link)}.breadcrumb .separator{opacity:0.5}.breadcrumb .current{color:var(--color-text-secondary)}.projects-page,.tools-page{padding:3rem 0;min-height:calc(100vh - 200px)}.page-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border);position:relative;display:flex;flex-wrap:wrap;align-items:baseline;gap:1rem}.page-header::after{content:'';position:absolute;bottom:-1px;left:0;width:30px;height:2px;background:var(--color-primary)}.page-title{font-size:1.8rem;font-weight:600;color:var(--color-text-primary);margin:0;letter-spacing:-0.02em;line-height:1.2}.page-description{font-size:1rem;color:var(--color-text-tertiary);margin:0;width:100%;margin-top:1rem}.page-stats{display:inline-block;padding:0.25rem 0.5rem;background:var(--color-primary-light);border-radius:4px;font-size:0.85rem;color:var(--color-primary);font-weight:500}.projects-grid,.tools-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:2rem;margin-top:3rem}.project-card,.tool-card{display:flex;flex-direction:column;padding:1.5rem;background:var(--color-bg-card);border-radius:8px;border:1px solid var(--color-border);text-decoration:none;box-shadow:var(--shadow-sm);transition:all 200ms ease-in-out;position:relative;overflow:hidden}.project-card::before,.tool-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-primary);transform:scaleX(0);transform-origin:left;transition:transform 200ms ease-in-out}.project-card:hover,.tool-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:var(--color-primary)}.project-card:hover::before,.tool-card:hover::before{transform:scaleX(1)}.project-card:hover .project-icon,.project-card:hover .tool-icon,.tool-card:hover .project-icon,.tool-card:hover .tool-icon{background:var(--color-primary);color:#fff}.project-card:hover .project-link,.project-card:hover .tool-link,.tool-card:hover .project-link,.tool-card:hover .tool-link{text-decoration:underline}.project-icon,.tool-icon{width:48px;height:48px;border-radius:8px;background:var(--color-bg-code);display:flex;align-items:center;justify-content:center;color:var(--color-primary);margin-bottom:1.5rem;transition:all 200ms ease-in-out;flex-shrink:0}.project-title,.tool-title{font-size:1.15rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem;line-height:1.3}.project-desc,.tool-desc{font-size:1rem;color:var(--color-text-secondary);line-height:1.6;flex:1}.project-updated,.tool-updated{font-size:0.85rem;color:var(--color-text-muted);margin-top:1rem}.project-link,.tool-link{font-size:0.9rem;color:var(--color-link);margin-top:1.5rem;transition:color 200ms ease-in-out;display:flex;align-items:center;gap:0.25rem;font-weight:500}.project-link svg,.tool-link svg{transition:transform 200ms ease-in-out}.project-card:hover .project-link svg,.tool-card:hover .tool-link svg{transform:translateX(3px)}@media (max-width: 768px){.projects-grid,.tools-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.page-stats{margin-top:0.25rem}}

/*# sourceMappingURL=style.css.map */