@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";body{margin:0}#root{min-height:100vh}:root{--bg:#faf9f5;--surface:#fff;--border:#e8e5de;--text:#4a4a48;--text-h:#1a1a19;--text-muted:#8a8a88;--accent:#d97757;--accent-hover:#c4623f;--green:#16a34a;--red:#dc2626;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--font:"Inter", -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:232px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{align-items:center;gap:12px;padding:24px 20px 20px;display:flex}.brand-icon{background:var(--accent);color:#fff;border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:700;display:flex}.brand-title{color:var(--text-h);font-size:18px;font-weight:700}.brand-sub{color:var(--text-muted);font-size:12px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:8px 12px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text);align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text-h)}.nav-item.active{background:var(--accent);color:#fff}.nav-item.active:hover{background:var(--accent-hover);color:#fff}.sidebar-links{border-top:1px solid var(--border);padding:12px}.links-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:0 12px 8px;font-size:11px;font-weight:600}.nav-link-ext{border-radius:var(--radius-sm);color:var(--text-muted);align-items:center;gap:8px;padding:8px 12px;font-size:13px;text-decoration:none;transition:all .15s;display:flex}.nav-link-ext:hover{background:var(--bg);color:var(--accent)}.sidebar-footer{color:var(--text-muted);border-top:1px solid var(--border);padding:16px 20px;font-size:11px}.main-content{flex:1;min-height:100vh;margin-left:232px}.page{max-width:960px;margin:0 auto;padding:32px 40px}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-header h1{color:var(--text-h);font-size:24px;font-weight:700}.header-actions{gap:8px;display:flex}.filter-bar{gap:6px;display:flex}.filter-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:13px;transition:all .15s}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn-sm{padding:5px 12px;font-size:13px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);color:#fff}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg)}.btn-danger{color:var(--red);background:0 0;border-color:#0000}.btn-danger:hover{background:#fef2f2}.status-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:24px 0 12px;font-size:13px;font-weight:600}.section-label:first-of-type{margin-top:0}.projects-grid-2col{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:8px;display:grid}.projects-grid-3col{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.project-card-report{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:inherit;padding:22px 24px;text-decoration:none;transition:box-shadow .2s,border-color .2s;display:block}.project-card-report:hover{box-shadow:var(--shadow-md);border-color:var(--accent);color:inherit}.project-card-compact{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:inherit;padding:16px 18px;text-decoration:none;transition:box-shadow .2s,border-color .2s;display:block}.project-card-compact:hover{box-shadow:var(--shadow);border-color:var(--accent);color:inherit}.compact-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.compact-title{color:var(--text-h);font-size:15px;font-weight:600}.compact-right{align-items:center;gap:8px;display:flex}.delete-x{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;transition:all .15s;display:flex}.delete-x:hover{color:var(--red);background:#fef2f2}.compact-desc{color:var(--text-muted);margin-bottom:8px;font-size:13px;line-height:1.4}.compact-tags .tech-tag{padding:1px 8px;font-size:11px}.compact-meta{color:var(--text-muted);gap:10px;margin-top:8px;font-size:12px;display:flex}.report-top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.report-title{color:var(--text-h);margin:0;font-size:20px;font-weight:700}.status-dot-wrap{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.report-desc{color:var(--text);margin-bottom:16px;font-size:14px;line-height:1.7}.report-meta{color:var(--text-muted);gap:20px;margin-bottom:12px;font-size:13px;display:flex}.report-meta span{align-items:center;gap:4px;display:flex}.report-progress{border-top:1px solid var(--border);align-items:baseline;gap:10px;padding-top:12px;font-size:13px;display:flex}.progress-label{color:var(--accent);flex-shrink:0;font-weight:500}.progress-text{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.report-links{border-top:1px solid var(--border);gap:8px;margin-top:14px;padding-top:12px;display:flex}.link-chip{border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.link-chip.link-live{color:#15803d;background:#dcfce7}.link-chip.link-live:hover{color:#15803d;background:#bbf7d0}.link-chip.link-github{color:#374151;background:#f3f4f6}.link-chip.link-github:hover{color:#374151;background:#e5e7eb}.detail-links{gap:10px;margin-bottom:24px;display:flex}.link-btn{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.link-btn.link-live{background:var(--accent);color:#fff}.link-btn.link-live:hover{background:var(--accent-hover);color:#fff}.link-btn.link-github{color:#fff;background:#24292e}.link-btn.link-github:hover{color:#fff;background:#1b1f23}.card-actions{gap:8px;display:flex}.back-link{color:var(--text-muted);margin-bottom:20px;font-size:13px;display:inline-block}.back-link:hover{color:var(--accent)}.detail-hero{align-items:center;gap:14px;margin-bottom:16px;display:flex}.detail-hero h1{color:var(--text-h);font-size:28px;font-weight:700}.status-pill{border-radius:20px;padding:4px 14px;font-size:13px;font-weight:500}.status-pill.status-active{color:#15803d;background:#dcfce7}.status-pill.status-paused{color:#a16207;background:#fef9c3}.status-pill.status-archived{color:#6b7280;background:#f3f4f6}.detail-description{color:var(--text);margin-bottom:28px;font-size:15px;line-height:1.8}.detail-info-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);gap:32px;margin-bottom:32px;padding:20px 24px;display:flex}.info-item{flex-direction:column;gap:4px;display:flex}.info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.info-value{color:var(--text-h);font-size:14px;font-weight:500}.detail-section{margin-top:8px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h2{color:var(--text-h);font-size:18px;font-weight:600}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:8px;bottom:8px;left:4px}.timeline-item{padding-bottom:16px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--accent);border:2px solid var(--bg);border-radius:50%;width:9px;height:9px;position:absolute;top:6px;left:-22px}.timeline-content{justify-content:space-between;align-items:baseline;gap:16px;display:flex}.timeline-msg{color:var(--text);font-size:14px;line-height:1.5}.timeline-date{color:var(--text-muted);flex-shrink:0;font-size:12px}.empty-inline{color:var(--text-muted);font-size:14px;font-style:italic}.diary-list{flex-direction:column;gap:16px;display:flex}.diary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:box-shadow .2s}.diary-card:hover{box-shadow:var(--shadow-md)}.diary-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.diary-title{color:var(--text-h);font-size:17px;font-weight:600}.diary-title:hover{color:var(--accent)}.diary-date{color:var(--text-muted);font-size:12px}.diary-tags{gap:6px;margin-bottom:10px;display:flex}.tag{background:var(--bg);color:var(--text-muted);border-radius:12px;padding:2px 10px;font-size:12px}.diary-preview{color:var(--text);margin-bottom:14px;font-size:14px;line-height:1.6}.editor-form{flex-direction:column;gap:12px;display:flex}.editor-title{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-h);font-size:22px;font-weight:600;font-family:var(--font);outline:none;padding:12px 16px}.editor-title:focus{border-color:var(--accent)}.editor-tags{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:14px;font-family:var(--font);outline:none;padding:10px 16px}.editor-tags:focus{border-color:var(--accent)}.editor-content{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);min-height:500px;color:var(--text);font-size:14px;line-height:1.7;font-family:var(--font-mono);resize:vertical;outline:none;padding:16px}.editor-content:focus{border-color:var(--accent)}.markdown-preview{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);min-height:500px;padding:24px;font-size:14px;line-height:1.8}.markdown-preview h1{color:var(--text-h);margin:16px 0 8px;font-size:24px}.markdown-preview h2{color:var(--text-h);margin:14px 0 6px;font-size:20px}.markdown-preview h3{color:var(--text-h);margin:12px 0 4px;font-size:16px}.markdown-preview p{margin-bottom:12px}.markdown-preview code{background:var(--bg);font-family:var(--font-mono);border-radius:4px;padding:2px 6px;font-size:13px}.markdown-preview pre{color:#cdd6f4;border-radius:var(--radius-sm);background:#1e1e2e;margin-bottom:12px;padding:16px;overflow-x:auto}.markdown-preview pre code{color:inherit;background:0 0;padding:0}.markdown-preview ul,.markdown-preview ol{margin-bottom:12px;padding-left:24px}.markdown-preview blockquote{border-left:3px solid var(--accent);color:var(--text-muted);margin-bottom:12px;padding-left:16px}.loading{min-height:300px;color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.empty{text-align:center;color:var(--text-muted);padding:60px 20px}.tech-tags{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.tech-tag{color:#4361ee;background:#f0f4ff;border-radius:12px;padding:2px 10px;font-size:12px;font-weight:500}.claude-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;padding:24px}.claude-section h2{color:var(--text-h);margin-bottom:16px;font-size:18px;font-weight:600}.cmd-list{flex-direction:column;gap:10px;display:flex}.cmd-item{align-items:center;gap:12px;display:flex}.cmd-label{color:var(--text-muted);flex-shrink:0;min-width:110px;font-size:13px}.cmd-code{font-family:var(--font-mono);background:var(--bg);white-space:nowrap;border-radius:6px;flex:1;padding:6px 12px;font-size:13px;overflow-x:auto}.copy-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;flex-shrink:0;padding:4px 12px;font-size:12px;transition:all .15s}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.claude-badge{color:#15803d;background:#dcfce7;border-radius:8px;align-items:center;gap:6px;margin-top:14px;padding:6px 14px;font-size:13px;font-weight:500;display:inline-flex}.related-list{flex-wrap:wrap;gap:8px;display:flex}.related-chip{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:20px;padding:6px 14px;font-size:13px;text-decoration:none;transition:all .15s}.related-chip:hover{border-color:var(--accent);color:var(--accent)}.notes-section{margin-top:8px}.notes-textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;min-height:200px;font-family:var(--font-mono);resize:vertical;box-sizing:border-box;outline:none;padding:16px;font-size:14px;line-height:1.7}.notes-textarea:focus{border-color:var(--accent)}.notes-view{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;font-size:14px;line-height:1.8}.project-form{flex-direction:column;gap:12px;max-width:600px;display:flex}.project-form label{color:var(--text-h);margin-top:4px;font-size:13px;font-weight:600}.project-form input,.project-form textarea{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font);background:var(--surface);outline:none;padding:10px 14px}.project-form input:focus,.project-form textarea:focus{border-color:var(--accent)}.project-form .btn{align-self:flex-start;margin-top:8px}@media (width<=768px){.sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;align-items:center;width:100%;padding:8px 16px;position:relative}.sidebar-brand{padding:0}.sidebar-nav{flex-direction:row;gap:4px;padding:0}.sidebar-footer{display:none}.main-content{margin-left:0}.app-shell{flex-direction:column}.page{padding:20px 16px}.projects-grid-2col{grid-template-columns:1fr}.projects-grid-3col{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;align-items:flex-start;gap:12px}}
