@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,500;0,9..40,700;1,9..40,300&family=DM+Mono:wght@400;500&display=swap";body{margin:0}#root{min-height:100vh}:root{--bg:#f4f0ea;--card:#fffefb;--text:#1c1814;--text2:#6d6560;--text3:#a59e96;--accent:#c96442;--accent-light:#e8916f;--accent-bg:#c964420f;--green:#2d7a4e;--green-bg:#2d7a4e12;--red:#bf3a2b;--red-bg:#bf3a2b12;--gold:#a97b10;--gold-bg:#a97b1012;--border:#1c181414;--radius:20px;--radius-sm:12px;--shadow:0 1px 2px #1c18140a, 0 2px 8px #1c181408;--shadow-md:0 4px 16px #1c18140f;--font:"DM Sans", -apple-system, BlinkMacSystemFont, "Noto Sans SC", sans-serif;--mono:"DM Mono", "SF Mono", Consolas, monospace}@media (prefers-color-scheme:dark){:root{--bg:#1a1816;--card:#242220;--text:#e8e4de;--text2:#a09890;--text3:#6d6560;--border:#ffffff14;--shadow:0 1px 2px #0003, 0 2px 8px #00000026;--shadow-md:0 4px 16px #0003;--accent-bg:#c964421a;--green-bg:#2d7a4e1f;--red-bg:#bf3a2b1f;--gold-bg:#a97b101f}.tech-tag{color:#7b9cff;background:#4361ee1f}.link-chip.link-github{color:#ccc;background:#ffffff14}.link-chip.link-github:hover{color:#eee;background:#ffffff24}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-light)}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--card);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);letter-spacing:-.3px;font-size:18px;font-weight:700}.brand-sub{color:var(--text3);font-size:12px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text2);align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background:var(--accent-bg);color:var(--text)}.nav-item.active{background:var(--accent);color:#fff}.nav-item.active:hover{background:var(--accent-light);color:#fff}.sidebar-links{border-top:1px solid var(--border);padding:12px}.links-label{color:var(--text3);text-transform:uppercase;letter-spacing:1.2px;padding:0 12px 8px;font-size:10px;font-weight:600}.nav-link-ext{border-radius:var(--radius-sm);color:var(--text3);align-items:center;gap:8px;padding:8px 12px;font-size:13px;text-decoration:none;transition:all .2s;display:flex}.nav-link-ext:hover{background:var(--accent-bg);color:var(--accent)}.sidebar-footer{color:var(--text3);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);letter-spacing:-.5px;font-size:24px;font-weight:700}.header-actions{align-items:center;gap:8px;display:flex}.filter-bar{gap:4px;display:flex}.filter-btn{color:var(--text3);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;background:0 0;border:none;border-radius:20px;padding:4px 14px;transition:all .2s}.filter-btn:hover{background:var(--accent-bg);color:var(--text2)}.filter-btn.active{background:var(--accent);color:#fff}.btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--card);color:var(--text2);font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;transition:all .2s;display:inline-flex}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn:active{transform:scale(.97)}.btn-sm{padding:5px 12px;font-size:13px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #c9644233}.btn-primary:hover{background:var(--accent-light);border-color:var(--accent-light);color:#fff}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--accent-bg)}.btn-danger{color:var(--red);background:0 0;border-color:#0000}.btn-danger:hover{background:var(--red-bg)}.section-label{color:var(--text3);text-transform:uppercase;letter-spacing:1.2px;margin:24px 0 12px;font-size:10px;font-weight:600}.section-label:first-of-type{margin-top:0}.projects-grid-2col{grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:8px;display:grid}.projects-grid-3col{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.project-card-report{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);color:inherit;padding:20px;text-decoration:none;transition:box-shadow .25s cubic-bezier(.4,0,.2,1),transform .25s;display:block;position:relative;overflow:hidden}.project-card-report:before{content:"";background:linear-gradient(90deg,#0000,#fffc,#0000);height:1px;position:absolute;top:0;left:0;right:0}.project-card-report:hover{box-shadow:var(--shadow-md);color:inherit;transform:translateY(-1px)}.project-card-compact{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);color:inherit;padding:16px 18px;text-decoration:none;transition:box-shadow .25s,transform .25s;display:block}.project-card-compact:hover{box-shadow:var(--shadow-md);color:inherit;transform:translateY(-1px)}.compact-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.compact-title{color:var(--text);font-size:15px;font-weight:700}.compact-right{align-items:center;gap:8px;display:flex}.delete-x{width:22px;height:22px;color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;transition:all .15s;display:flex}.delete-x:hover{background:var(--red-bg);color:var(--red)}.compact-desc{color:var(--text2);margin-bottom:8px;font-size:12px;line-height:1.4}.compact-tags .tech-tag{padding:1px 8px;font-size:11px}.compact-meta{color:var(--text3);gap:10px;margin-top:8px;font-size:11px;font-weight:500;display:flex}.report-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.report-title{color:var(--text);letter-spacing:-.3px;margin:0;font-size:18px;font-weight:700}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.report-desc{color:var(--text2);margin-bottom:14px;font-size:13px;line-height:1.6}.report-meta{color:var(--text3);gap:16px;margin-bottom:10px;font-size:12px;font-weight:500;display:flex}.report-meta span{align-items:center;gap:4px;display:flex}.report-progress{border-top:1px solid var(--border);align-items:baseline;gap:8px;padding-top:10px;font-size:12px;display:flex}.progress-label{color:var(--accent);flex-shrink:0;font-weight:600}.progress-text{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.report-links{border-top:1px solid var(--border);gap:6px;margin-top:12px;padding-top:10px;display:flex}.link-chip{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.link-chip.link-live{background:var(--green-bg);color:var(--green)}.link-chip.link-live:hover{color:var(--green);background:#2d7a4e24}.link-chip.link-github{color:#24292e;background:#24292e14}.link-chip.link-github:hover{color:#24292e;background:#24292e24}.detail-links{gap:10px;margin-bottom:24px;display:flex}.link-btn{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.link-btn:active{transform:scale(.97)}.link-btn.link-live{background:var(--accent);color:#fff;box-shadow:0 2px 8px #c9644233}.link-btn.link-live:hover{background:var(--accent-light);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(--text3);margin-bottom:20px;font-size:12px;font-weight:500;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);letter-spacing:-1px;font-size:28px;font-weight:700}.status-pill{border-radius:20px;padding:4px 14px;font-size:12px;font-weight:600}.status-pill.status-active{background:var(--green-bg);color:var(--green)}.status-pill.status-paused{background:var(--gold-bg);color:var(--gold)}.status-pill.status-idea{background:var(--accent-bg);color:var(--accent)}.status-pill.status-archived{color:var(--text3);background:#1c18140a}.detail-description{color:var(--text2);margin-bottom:24px;font-size:14px;line-height:1.7}.detail-info-bar{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);gap:32px;margin-bottom:28px;padding:18px 22px;display:flex}.info-item{flex-direction:column;gap:3px;display:flex}.info-label{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.info-value{color:var(--text);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);letter-spacing:-.3px;font-size:16px;font-weight:700}.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:14px;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(--text2);font-size:13px;line-height:1.5}.timeline-date{color:var(--text3);font-size:11px;font-family:var(--mono);flex-shrink:0}.empty-inline{color:var(--text3);font-size:13px;font-style:italic}.diary-list{flex-direction:column;gap:14px;display:flex}.diary-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:box-shadow .25s,transform .25s}.diary-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.diary-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.diary-title{color:var(--text);font-size:16px;font-weight:700}.diary-title:hover{color:var(--accent)}.diary-date{color:var(--text3);font-size:11px;font-family:var(--mono)}.diary-tags{gap:6px;margin-bottom:10px;display:flex}.tag{background:var(--accent-bg);color:var(--accent);border-radius:20px;padding:2px 10px;font-size:11px;font-weight:500}.diary-preview{color:var(--text2);margin-bottom:14px;font-size:13px;line-height:1.6}.editor-form{flex-direction:column;gap:12px;display:flex}.editor-title{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:20px;font-weight:700;font-family:var(--font);outline:none;padding:14px 16px}.editor-title:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.editor-tags{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text2);font-size:14px;font-family:var(--font);outline:none;padding:12px 16px}.editor-tags:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.editor-content{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);min-height:500px;color:var(--text);font-size:14px;line-height:1.7;font-family:var(--mono);resize:vertical;outline:none;padding:16px}.editor-content:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.markdown-preview{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);min-height:500px;padding:24px;font-size:14px;line-height:1.8}.markdown-preview h1{color:var(--text);letter-spacing:-.5px;margin:16px 0 8px;font-size:24px;font-weight:700}.markdown-preview h2{color:var(--text);margin:14px 0 6px;font-size:20px;font-weight:700}.markdown-preview h3{color:var(--text);margin:12px 0 4px;font-size:16px;font-weight:600}.markdown-preview p{color:var(--text2);margin-bottom:12px}.markdown-preview code{background:var(--bg);font-family:var(--mono);border-radius:6px;padding:2px 6px;font-size:13px}.markdown-preview pre{color:#e8e4de;border-radius:var(--radius-sm);background:#1a1816;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(--text3);margin-bottom:12px;padding-left:16px}.loading{min-height:300px;color:var(--text3);justify-content:center;align-items:center;font-size:14px;display:flex}.empty{text-align:center;color:var(--text3);padding:60px 20px}.tech-tags{flex-wrap:wrap;gap:4px;margin-bottom:12px;display:flex}.tech-tag{color:#4361ee;background:#f0f4ff;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600}.claude-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:24px;padding:22px}.claude-section h2{color:var(--text);margin-bottom:16px;font-size:16px;font-weight:700}.cmd-list{flex-direction:column;gap:10px;display:flex}.cmd-item{align-items:center;gap:12px;display:flex}.cmd-label{color:var(--text3);flex-shrink:0;min-width:110px;font-size:12px;font-weight:500}.cmd-code{font-family:var(--mono);background:var(--bg);border-radius:var(--radius-sm);white-space:nowrap;flex:1;padding:8px 12px;font-size:12px;overflow-x:auto}.copy-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--text2);cursor:pointer;font-size:12px;font-family:var(--font);flex-shrink:0;padding:6px 12px;font-weight:500;transition:all .2s}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.copy-btn:active{transform:scale(.97)}.claude-badge{background:var(--green-bg);color:var(--green);border-radius:20px;align-items:center;gap:6px;margin-top:14px;padding:6px 14px;font-size:12px;font-weight:600;display:inline-flex}.related-list{flex-wrap:wrap;gap:8px;display:flex}.related-chip{background:var(--accent-bg);color:var(--accent);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s}.related-chip:hover{color:var(--accent);background:#c964421f}.notes-section{margin-top:8px}.notes-textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;min-height:200px;font-family:var(--mono);resize:vertical;box-sizing:border-box;color:var(--text);outline:none;padding:16px;font-size:13px;line-height:1.7}.notes-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.notes-view{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);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(--text2);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:12px;font-weight:600}.project-form input,.project-form textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font);background:var(--bg);color:var(--text);outline:none;padding:14px 16px}.project-form input:focus,.project-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.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,.sidebar-links{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}}
