:root{--bg: #f2f2f2;--surface: #ffffff;--border: #e5e5ea;--text: #1c1c1e;--text-secondary: #8e8e93;--accent: #007aff;--accent-purple: #5856d6;--cat-web: #ff3b30;--cat-mobile: #007aff;--cat-oss: #34c759;--cat-auto: #5856d6;--cat-newsletter: #ff9500;--cat-blog: #32ade6}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;font-size:14px;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a,a:visited{color:var(--accent)}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-body{display:flex;flex:1;overflow:hidden}.title-bar{height:36px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px;position:relative;flex-shrink:0;z-index:100}.title-bar-dots{display:flex;gap:8px;align-items:center}.title-bar-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.dot-red{background:#ff5f57;border:1px solid #e0443e}.dot-yellow{background:#ffbd2e;border:1px solid #dea123}.dot-green{background:#28c840;border:1px solid #1aab29}.title-bar-center{position:absolute;left:50%;transform:translate(-50%);font-size:12px;color:var(--text-secondary);font-weight:500;white-space:nowrap;pointer-events:none}.title-bar-mobile-label{display:none;font-size:13px;font-weight:500;color:var(--text);margin-left:12px}.title-bar-nav{display:flex;gap:4px;margin-left:auto}.title-bar-nav a{font-size:12px;padding:4px 10px;border-radius:14px;text-decoration:none;color:var(--text-secondary);transition:background .15s,color .15s;font-weight:500}.title-bar-nav a:hover{background:var(--bg);color:var(--text)}.title-bar-nav a.active{background:var(--accent);color:#fff}.sidebar{width:195px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;padding-top:16px}.sidebar-top{padding:0 12px;display:flex;flex-direction:column;align-items:center;gap:6px}.sidebar-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#5856d6,#af52de);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;box-shadow:0 4px 12px #5856d659;flex-shrink:0}.sidebar-name{font-size:14px;font-weight:600;color:var(--text);text-align:center}.sidebar-tagline{font-size:10px;color:var(--text-secondary);text-align:center;line-height:1.4;font-style:italic}.sidebar-divider{height:1px;background:var(--border);margin:12px 0;flex-shrink:0}.sidebar-section-label{padding:0 12px 6px;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);font-weight:600}.sidebar-nav{display:flex;flex-direction:column;flex:1}.sidebar-nav-item{display:flex;align-items:center;gap:9px;padding:7px 12px;text-decoration:none;color:var(--text);font-size:13px;border-left:2px solid transparent;transition:background .1s}.sidebar-nav-item:hover{background:var(--bg);color:var(--text)}.sidebar-nav-item.active{background:#5856d612;border-left-color:var(--accent-purple)}.sidebar-nav-icon{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.sidebar-nav-label{flex:1}.sidebar-nav-count{font-size:11px;color:var(--text-secondary);background:var(--bg);padding:1px 6px;border-radius:8px}.sidebar-stats{border-top:1px solid var(--border);padding:10px 12px;display:flex;justify-content:space-around;margin-top:auto;flex-shrink:0}.sidebar-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.sidebar-stat-value{font-size:13px;font-weight:600;color:var(--text)}.sidebar-stat-label{font-size:9px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.content-area{flex:1;background:var(--surface);overflow-y:auto;padding:24px;min-width:0}.content-header{margin-bottom:16px}.content-title{font-size:20px;font-weight:700;letter-spacing:-.4px;color:var(--text);margin:0 0 4px}.content-subtitle{font-size:12px;color:var(--text-secondary);margin:0}.filter-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.filter-pill{font-size:12px;padding:5px 12px;border-radius:14px;background:var(--bg);color:#3a3a3c;border:none;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.filter-pill:hover{background:#e5e5ea}.filter-pill.active{background:var(--accent-purple);color:#fff}.app-icon-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-bottom:24px}@keyframes descPanelIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.blog-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:12px;overflow:hidden}.blog-card{background:var(--surface);padding:14px 16px;display:flex;flex-direction:column;gap:4px;text-decoration:none;color:inherit;transition:background .1s}.blog-card:hover{background:#fafafa}.blog-card-date{font-size:11px;color:var(--text-secondary)}.blog-card-title{font-size:15px;font-weight:600;color:var(--text);margin:0;line-height:1.3}.blog-card-excerpt{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card-arrow{font-size:12px;color:var(--accent);align-self:flex-end;margin-top:2px}.blog-post-wrapper{max-width:680px}.blog-post-title{font-size:26px;font-weight:700;letter-spacing:-.5px;color:var(--text);margin:0 0 8px}.blog-post-meta{font-size:12px;color:var(--text-secondary);margin-bottom:24px}.blog-body{font-size:15px;line-height:1.7;color:#3a3a3c}.blog-body h1,.blog-body h2,.blog-body h3{color:var(--text);margin-top:28px}.blog-body p{margin:0 0 14px}.blog-body pre{background:#1c1c1e;color:#afa;padding:14px 16px;border-radius:10px;overflow-x:auto;font-size:13px}.blog-body code{font-family:SF Mono,Fira Code,monospace;background:var(--bg);padding:1px 5px;border-radius:4px;font-size:13px}.blog-body pre code{background:none;padding:0}.back-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--accent);text-decoration:none;margin-bottom:20px}.back-link:hover{text-decoration:underline}.project-detail-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.project-detail-icon{width:72px;height:72px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}.project-detail-title{font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px;color:var(--text)}.project-detail-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:16px}.category-pill,.stat-badge{font-size:11px;padding:3px 8px;border-radius:8px;font-weight:500;color:#fff}.tag-pill{font-size:11px;padding:3px 8px;border-radius:8px;background:var(--bg);color:#3a3a3c;border:1px solid var(--border)}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.project-detail-description{font-size:15px;line-height:1.7;color:#3a3a3c;max-width:640px;margin-bottom:24px}.visit-button{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--accent);color:#fff;border-radius:10px;text-decoration:none;font-size:14px;font-weight:500;transition:opacity .15s}.visit-button:hover{opacity:.85;color:#fff}.about-wrapper{max-width:540px}.about-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#5856d6,#af52de);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:26px;margin-bottom:16px;box-shadow:0 4px 16px #5856d659}.about-name{font-size:22px;font-weight:700;margin:0 0 4px;color:var(--text)}.about-tagline{font-size:14px;color:var(--text-secondary);margin:0 0 20px}.about-bio{font-size:15px;line-height:1.7;color:#3a3a3c;margin-bottom:24px}.about-links{display:flex;gap:10px;flex-wrap:wrap}.about-link{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg);color:var(--text);border-radius:10px;text-decoration:none;font-size:13px;font-weight:500;border:1px solid var(--border);transition:background .15s}.about-link:hover{background:#e5e5ea;color:var(--text)}.site-footer{background:var(--surface);border-top:1px solid var(--border);padding:10px 24px;font-size:12px;color:var(--text-secondary);text-align:center;flex-shrink:0}.bottom-tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--surface);border-top:1px solid var(--border);justify-content:space-around;align-items:center;z-index:100}.bottom-tab-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;text-decoration:none;transition:opacity .15s,filter .15s}.bottom-tab-icon:not(.active){filter:grayscale(1);opacity:.45}@media(max-width:768px){.sidebar{display:none}.bottom-tab-bar{display:flex}.title-bar-center{display:none}.title-bar-mobile-label{display:block}.content-area{padding:16px 16px 80px}}@media(max-width:500px){.app-icon-grid{grid-template-columns:repeat(3,1fr)!important}}
