:root,[data-theme=light]{--color-bg: #ffffff;--color-text: #000000;--color-text-muted: #666666;--color-border: #000000;--color-border-light: #dddddd;--color-bg-secondary: #f8f8f8;--color-bg-tertiary: #f4f4f4;--color-error: #e74c3c;--color-success: #27ae60;--color-link: #3498db}[data-theme=dark]{--color-bg: #1a1a1a;--color-text: #e0e0e0;--color-text-muted: #999999;--color-border: #e0e0e0;--color-border-light: #333333;--color-bg-secondary: #252525;--color-bg-tertiary: #2a2a2a;--color-error: #ff6b6b;--color-success: #4ade80;--color-link: #60a5fa}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--color-bg);color:var(--color-text);transition:background-color .3s ease,color .3s ease}.theme-toggle{position:fixed;top:1.5rem;right:1.5rem;font-family:VT323,monospace;font-size:1.1rem;padding:.4rem .8rem;border:2px solid var(--color-text);background:var(--color-bg);color:var(--color-text);cursor:pointer;transition:all .2s ease;z-index:1000}.theme-toggle:hover{background:var(--color-text);color:var(--color-bg)}.home-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;width:100%;background-color:var(--color-bg);padding:2rem}.home-intro{text-align:center;max-width:600px}.home-intro h1{margin-bottom:1rem}.home-intro p{font-family:VT323,monospace;font-size:1.4rem;line-height:1.6;color:var(--color-text)}.inline-link{text-decoration:underline;color:var(--color-text);transition:all .2s ease}.inline-link:hover{background:var(--color-text);color:var(--color-bg);text-decoration:none;padding:0 .2rem}.like-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:VT323,monospace;font-size:1.2rem;background:transparent;border:2px solid var(--color-border);color:var(--color-text);cursor:pointer;transition:all .2s ease}.like-button:hover:not(:disabled){background:var(--color-text);color:var(--color-bg)}.like-button:disabled{cursor:default}.like-button.liked{border-color:var(--color-error);color:var(--color-error)}.like-button.liked .heart{animation:pulse .3s ease}@keyframes pulse{50%{transform:scale(1.3)}}.project-card{border:2px solid var(--color-border);padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease;background:var(--color-bg)}.project-card:hover{transform:translateY(-4px);box-shadow:4px 4px 0 var(--color-border)}.card-link{display:block;text-decoration:none;color:inherit}.card-title{margin:0 0 .5rem;font-size:1.5rem}.card-description{font-family:VT323,monospace;font-size:1.1rem;color:var(--color-text);margin:0 0 1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{display:flex;justify-content:space-between;align-items:center;font-family:VT323,monospace;font-size:1rem;margin-bottom:1rem}.status-badge{padding:.25rem .5rem;border:1px solid currentColor}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--color-border-light)}.external-link{font-family:VT323,monospace;font-size:1.1rem;padding:.5rem 1rem;border:2px solid var(--color-border);transition:all .2s ease}.external-link:hover{background:var(--color-text);color:var(--color-bg);text-decoration:none}.build-in-public{min-height:100vh;padding:2rem;max-width:1400px;margin:0 auto;background-color:var(--color-bg)}.build-in-public h1{text-align:center;margin-bottom:.5rem}.page-description{font-family:VT323,monospace;font-size:1.2rem;text-align:center;color:var(--color-text-muted);margin-bottom:3rem}.loading,.error,.empty{font-family:VT323,monospace;font-size:1.2rem;text-align:center;padding:3rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(490px,1fr));gap:2rem}@media(max-width:768px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:400px){.projects-grid{grid-template-columns:1fr}}.tweet-embed{margin:0;min-height:200px;width:100%}.tweet-embed>div{width:100%!important}.tweet-embed twitter-widget,.tweet-embed .twitter-tweet{width:100%!important;max-width:100%!important}.tweet-loading{font-family:VT323,monospace;font-size:1.2rem;color:var(--color-text-muted);padding:2rem;border:2px dashed var(--color-border-light);width:100%;text-align:center}.tweet-error{flex-direction:column;gap:1rem;padding:2rem;border:2px solid var(--color-error);background:#e74c3c1a}.tweet-error p{font-family:VT323,monospace;font-size:1.2rem;margin:0;color:var(--color-error)}.tweet-error a{font-family:VT323,monospace;font-size:1rem;color:var(--color-error)}.project-page{min-height:100vh;padding:2rem;max-width:900px;margin:0 auto;background-color:var(--color-bg)}.breadcrumb{font-family:VT323,monospace;font-size:1rem;margin-bottom:2rem;color:var(--color-text-muted)}.breadcrumb a{color:var(--color-text)}.breadcrumb a:hover{text-decoration:underline}.project-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--color-border)}.project-header h1{margin-bottom:1rem}.project-description{font-family:VT323,monospace;font-size:1.3rem;color:var(--color-text);margin-bottom:1.5rem;line-height:1.4}.project-meta{display:flex;gap:1.5rem;align-items:center;margin-bottom:1.5rem;font-family:VT323,monospace;font-size:1.1rem}.status-badge{padding:.25rem .75rem;border:2px solid currentColor}.date-range{color:var(--color-text-muted)}.project-actions{display:flex;gap:1rem;align-items:center}.visit-link{font-family:VT323,monospace;font-size:1.2rem;padding:.5rem 1rem;border:2px solid var(--color-border);transition:all .2s ease}.visit-link:hover{background:var(--color-text);color:var(--color-bg);text-decoration:none}.tweets-section h2{margin-bottom:1.5rem}.no-tweets{font-family:VT323,monospace;font-size:1.2rem;color:var(--color-text-muted);text-align:center;padding:3rem;border:2px dashed var(--color-border-light)}.tweets-timeline{column-count:3;column-gap:16px}.tweets-timeline>*{break-inside:avoid;margin-bottom:16px;display:inline-block;width:100%}@media(max-width:1024px){.tweets-timeline{column-count:2}}@media(max-width:640px){.tweets-timeline{column-count:1}}.loading,.error{font-family:VT323,monospace;font-size:1.2rem;text-align:center;padding:3rem}.error{color:var(--color-error)}.back-link{display:block;text-align:center;font-family:VT323,monospace;font-size:1.2rem;margin-top:1rem}.writes-page{min-height:100vh;max-width:1400px;margin:0 auto;padding:2rem;background-color:var(--color-bg)}.writes-breadcrumb{font-family:VT323,monospace;font-size:1rem;margin-bottom:2rem;color:var(--color-text-muted)}.writes-breadcrumb a{color:var(--color-text)}.writes-breadcrumb a:hover{text-decoration:underline}.writes-layout{display:grid;grid-template-columns:30% 70%;gap:3rem;min-height:calc(100vh - 150px)}.writes-sidebar{position:sticky;top:2rem;height:fit-content;max-height:calc(100vh - 4rem);overflow-y:auto}.current-topic{margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--color-border)}.current-topic h1{font-size:2rem;margin-bottom:.5rem;text-transform:lowercase}.current-topic p{font-family:VT323,monospace;font-size:1.2rem;color:var(--color-text-muted);margin:0}.topic-list{list-style:none;padding:0;margin:0}.topic-list li{margin-bottom:.75rem}.topic-list a{font-family:VT323,monospace;font-size:1.3rem;color:var(--color-text-muted);display:block;padding:.5rem 0;transition:color .2s}.topic-list a:hover{color:var(--color-text)}.topic-list a.active{color:var(--color-text);position:relative}.topic-list a.active:before{content:"> "}.writes-content{padding-left:2rem;border-left:2px solid var(--color-border)}.sections-list{display:flex;flex-direction:column;gap:4rem}.section-item{padding-bottom:3rem}.section-item:not(:last-child){border-bottom:1px solid var(--color-border-light)}.section-item h2{font-size:1.5rem;margin-bottom:1.5rem;text-transform:lowercase}.section-content{font-family:VT323,monospace;font-size:1.2rem;line-height:1.6;color:var(--color-text)}.section-content p{margin-bottom:1rem}.section-content h3{font-size:1.3rem;margin:2rem 0 1rem}.section-content a{color:var(--color-text);text-decoration:underline}.section-content a:hover{background:var(--color-text);color:var(--color-bg)}.section-content img{max-width:100%;height:auto;margin:1.5rem 0;border:2px solid var(--color-border)}.section-content blockquote{border-left:3px solid var(--color-border);margin:1.5rem 0;padding-left:1.5rem;font-style:italic;color:var(--color-text-muted)}.section-content ul,.section-content ol{margin:1rem 0;padding-left:2rem}.section-content li{margin-bottom:.5rem}.section-content code{background:var(--color-bg-tertiary);padding:.2rem .4rem;font-family:monospace;font-size:.9em}.section-content pre{background:var(--color-bg-tertiary);padding:1rem;overflow-x:auto;border:1px solid var(--color-border-light);margin:1.5rem 0}.section-content pre code{padding:0;background:none}.writes-empty{font-family:VT323,monospace;font-size:1.3rem;text-align:center;padding:4rem 2rem;color:var(--color-text-muted)}.writes-loading{font-family:VT323,monospace;font-size:1.3rem;text-align:center;padding:4rem 2rem}@media(max-width:768px){.writes-layout{grid-template-columns:1fr;gap:2rem}.writes-sidebar{position:static;max-height:none}.current-topic{margin-bottom:1.5rem;padding-bottom:1rem}.topic-list{display:flex;flex-wrap:wrap;gap:.5rem}.topic-list li{margin-bottom:0}.topic-list a{padding:.3rem .8rem;border:1px solid var(--color-border-light);font-size:1.1rem}.topic-list a.active{border-color:var(--color-border);background:var(--color-text);color:var(--color-bg)}.topic-list a.active:before{content:""}.writes-content{padding-left:0;border-left:none;border-top:2px solid var(--color-border);padding-top:2rem}.sections-list{gap:2rem}.section-item{padding-bottom:2rem}}.admin-login{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh}.admin-login h1{margin-bottom:2rem}.admin-login form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:600px}.admin-login input{font-family:VT323,monospace;font-size:1.2rem;padding:.75rem 1rem;border:2px solid var(--color-border);background:var(--color-bg);color:var(--color-text);outline:none}.admin-login input:focus{box-shadow:4px 4px 0 var(--color-border)}.password-field{position:relative;display:flex;align-items:stretch}.password-field input{flex:1;padding-right:3rem}.toggle-password{position:absolute;right:0;top:0;bottom:0;width:3rem;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding:0;color:var(--color-text)}.toggle-password:hover{background:transparent;color:inherit}.admin-login button[type=submit]{font-family:VT323,monospace;font-size:1.2rem;padding:.75rem 1rem;border:2px solid var(--color-border);background:var(--color-text);color:var(--color-bg);cursor:pointer;transition:all .2s ease}.admin-login button[type=submit]:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.admin-login button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.admin-login .error{color:var(--color-error);font-family:VT323,monospace;font-size:1rem;text-align:center}.rich-text-editor{border:2px solid var(--color-border)}.editor-menu{display:flex;flex-wrap:wrap;gap:.25rem;padding:.5rem;border-bottom:2px solid var(--color-border);background:var(--color-bg-secondary)}.editor-menu button{font-family:VT323,monospace;font-size:1rem;padding:.3rem .6rem;border:1px solid var(--color-border-light);background:var(--color-bg);color:var(--color-text);cursor:pointer;transition:all .15s}.editor-menu button:hover:not(:disabled){background:var(--color-text);color:var(--color-bg);border-color:var(--color-border)}.editor-menu button.active{background:var(--color-text);color:var(--color-bg);border-color:var(--color-border)}.editor-menu button:disabled{opacity:.4;cursor:not-allowed}.editor-menu .divider{width:1px;background:var(--color-border-light);margin:0 .25rem}.editor-content{min-height:200px;max-height:400px;overflow-y:auto;background:var(--color-bg)}.editor-content .tiptap{padding:1rem;font-family:VT323,monospace;font-size:1.1rem;line-height:1.5;outline:none;color:var(--color-text)}.editor-content .tiptap:focus{outline:none}.editor-content .tiptap p{margin:0 0 .75rem}.editor-content .tiptap h2{font-size:1.4rem;margin:1.5rem 0 .75rem}.editor-content .tiptap h3{font-size:1.2rem;margin:1.25rem 0 .5rem}.editor-content .tiptap ul,.editor-content .tiptap ol{padding-left:1.5rem;margin:.5rem 0}.editor-content .tiptap li{margin-bottom:.25rem}.editor-content .tiptap blockquote{border-left:3px solid var(--color-border);margin:.75rem 0;padding-left:1rem;font-style:italic;color:var(--color-text-muted)}.editor-content .tiptap pre{background:var(--color-bg-tertiary);padding:.75rem;font-family:monospace;font-size:.9em;overflow-x:auto;margin:.75rem 0}.editor-content .tiptap code{background:var(--color-bg-tertiary);padding:.15rem .3rem;font-family:monospace;font-size:.9em}.editor-content .tiptap a{color:var(--color-text);text-decoration:underline}.editor-content .tiptap img{max-width:100%;height:auto;border:1px solid var(--color-border-light);margin:.75rem 0}.editor-content .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--color-text-muted);pointer-events:none;height:0}.admin-page{min-height:100vh;padding:2rem;max-width:900px;margin:0 auto;background-color:var(--color-bg)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.admin-header h1{margin:0}.logout-btn{font-family:VT323,monospace;font-size:1rem;padding:.5rem 1rem;border:2px solid var(--color-border);background:transparent;color:var(--color-text);cursor:pointer}.logout-btn:hover{background:var(--color-text);color:var(--color-bg)}.message{font-family:VT323,monospace;font-size:1.1rem;padding:1rem;margin-bottom:1rem;border:2px solid}.message.error{border-color:var(--color-error);background:#e74c3c1a;color:var(--color-error)}.message.success{border-color:var(--color-success);background:#27ae601a;color:var(--color-success)}.admin-section{margin-bottom:3rem}.admin-section h2{margin-bottom:1rem}.project-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;gap:1rem}.form-row input,.form-row select{flex:1}.project-form input,.project-form select,.project-form textarea{font-family:VT323,monospace;font-size:1.1rem;padding:.75rem;border:2px solid var(--color-border);background:var(--color-bg);color:var(--color-text)}.project-form input:focus,.project-form select:focus,.project-form textarea:focus{outline:none;box-shadow:4px 4px 0 var(--color-border)}.checkbox-label{font-family:VT323,monospace;font-size:1.1rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--color-text)}.checkbox-label input{width:1.2rem;height:1.2rem}.form-actions{display:flex;gap:1rem}.form-actions button,.project-actions button,.add-tweet button{font-family:VT323,monospace;font-size:1.1rem;padding:.75rem 1.5rem;border:2px solid var(--color-border);background:var(--color-text);color:var(--color-bg);cursor:pointer;transition:all .2s ease}.form-actions button:hover,.project-actions button:hover,.add-tweet button:hover{background:var(--color-bg);color:var(--color-text)}.form-actions button:last-child{background:transparent;color:var(--color-text)}.projects-list{display:flex;flex-direction:column;gap:1.5rem}.project-item{border:2px solid var(--color-border);padding:1.5rem}.project-item.hidden{opacity:.6;border-style:dashed}.project-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.project-info h3{margin:0;font-size:1.3rem}.status-badge{font-family:VT323,monospace;font-size:.9rem;padding:.25rem .5rem;border:1px solid currentColor}.status-in-progress{color:var(--color-success)}.status-idea{color:var(--color-link)}.status-paused{color:#f39c12}.status-completed{color:#9b59b6}.status-abandoned{color:#95a5a6}.hidden-badge{font-family:VT323,monospace;font-size:.9rem;padding:.25rem .5rem;background:var(--color-bg-secondary);color:var(--color-text-muted)}.project-actions{display:flex;gap:.5rem;margin-bottom:1rem}.project-actions button{padding:.5rem 1rem;font-size:1rem}.project-actions button.danger{border-color:var(--color-error);background:var(--color-error)}.project-actions button.danger:hover{background:var(--color-bg);color:var(--color-error)}.tweets-manager{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.tweets-manager h4{font-family:VT323,monospace;font-size:1.1rem;margin-bottom:.5rem}.add-tweet{display:flex;gap:.5rem;margin-bottom:.5rem}.add-tweet input{flex:1;font-family:VT323,monospace;font-size:1rem;padding:.5rem;border:2px solid var(--color-border);background:var(--color-bg);color:var(--color-text)}.add-tweet button{padding:.5rem 1rem;font-size:1rem}.tweet-list{list-style:none;padding:0;margin:0}.tweet-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border-light);font-family:VT323,monospace;font-size:1rem}.tweet-list a{color:var(--color-link);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.tweet-list button.small{padding:.25rem .5rem;font-size:1rem;min-width:2rem}.admin-tabs{display:flex;gap:0;margin-bottom:2rem;border-bottom:2px solid var(--color-border)}.admin-tabs button{font-family:VT323,monospace;font-size:1.2rem;padding:.75rem 1.5rem;border:2px solid var(--color-border);border-bottom:none;background:transparent;color:var(--color-text);cursor:pointer;margin-bottom:-2px;transition:all .2s}.admin-tabs button:hover{background:var(--color-bg-secondary)}.admin-tabs button.active{background:var(--color-text);color:var(--color-bg)}.section-count{font-family:VT323,monospace;font-size:.9rem;color:var(--color-text-muted);margin-left:auto}.sections-manager{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.sections-manager h4{font-family:VT323,monospace;font-size:1.1rem;margin-bottom:1rem}.section-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.section-form input{font-family:VT323,monospace;font-size:1.1rem;padding:.5rem;border:2px solid var(--color-border);background:var(--color-bg);color:var(--color-text)}.section-form button{font-family:VT323,monospace;font-size:1rem;padding:.5rem 1rem;border:2px solid var(--color-border);background:var(--color-text);color:var(--color-bg);cursor:pointer;align-self:flex-start}.section-form button:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.section-form button:disabled{opacity:.5;cursor:not-allowed}.section-list{list-style:none;padding:0;margin:0}.section-item-admin{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:.75rem;border:1px solid var(--color-border-light);margin-bottom:.5rem}.section-title{font-family:VT323,monospace;font-size:1.1rem}.section-actions{display:flex;gap:.5rem}.section-actions button{font-family:VT323,monospace;font-size:.9rem;padding:.25rem .5rem;border:1px solid var(--color-border);background:transparent;color:var(--color-text);cursor:pointer}.section-actions button:hover{background:var(--color-text);color:var(--color-bg)}.section-actions button.danger{border-color:var(--color-error);color:var(--color-error)}.section-actions button.danger:hover{background:var(--color-error);color:var(--color-bg)}.section-edit-form{width:100%;display:flex;flex-direction:column;gap:.75rem}.section-edit-form input{font-family:VT323,monospace;font-size:1.1rem;padding:.5rem;border:2px solid var(--color-border);background:var(--color-bg);color:var(--color-text)}.section-edit-actions{display:flex;gap:.5rem}.section-edit-actions button{font-family:VT323,monospace;font-size:1rem;padding:.5rem 1rem;border:2px solid var(--color-border);background:var(--color-text);color:var(--color-bg);cursor:pointer}.section-edit-actions button:hover{background:var(--color-bg);color:var(--color-text)}.section-edit-actions button:last-child{background:transparent;color:var(--color-text)}@media(max-width:600px){.form-row{flex-direction:column}.project-actions{flex-wrap:wrap}.admin-tabs{flex-direction:column}.admin-tabs button{border-bottom:2px solid var(--color-border);margin-bottom:0}}h1,h2,h3{font-family:VT323,monospace;font-weight:400;color:var(--color-text);letter-spacing:.1em}h1{font-size:clamp(1.5rem,6vw,3rem)}h2{font-size:clamp(1.2rem,4vw,2rem)}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}
