@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.table{display:table}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}}:root,[data-theme=light]{--bg:#fff;--text:#000;--text-gray:#666;--text-light:#999;--link:#000;--link-hover:#666;--border:#eee;--border-dark:#ccc;--code-bg:#f5f5f5;--card-bg:#fafafa}[data-theme=dark]{--bg:#111;--text:#e0e0e0;--text-gray:#999;--text-light:#666;--link:#e0e0e0;--link-hover:#999;--border:#333;--border-dark:#444;--code-bg:#1a1a1a;--card-bg:#1a1a1a}*{box-sizing:border-box}html{font-size:14px}body{background:var(--bg);color:var(--text);margin:0;padding:0;font-family:Verdana,Geneva,sans-serif;line-height:1.6;transition:background .2s,color .2s}a{color:var(--link);text-decoration:underline}a:hover{color:var(--text-gray)}.controls{z-index:100;gap:8px;display:flex;position:fixed;top:15px;right:15px}.dark-mode-toggle,.terminal-toggle{border:1px solid var(--border-dark);cursor:pointer;color:var(--text);background:0 0;padding:5px 10px;font-family:monospace;font-size:14px;transition:all .2s}.dark-mode-toggle:hover,.terminal-toggle:hover{border-color:var(--text-gray)}.page-transition{opacity:0;transition:opacity .3s,transform .3s;transform:translateY(5px)}.page-transition.visible{opacity:1;transform:translateY(0)}.spotify-widget{color:var(--text-gray);border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:10px;padding:8px 0;font-size:12px;display:flex}.spotify-icon{font-size:14px}.spotify-info{color:inherit;flex-direction:column;text-decoration:none;display:flex}.spotify-info:hover{color:var(--text)}.spotify-title{color:var(--text);font-weight:700}.spotify-artist{font-size:11px}.spotify-offline{font-style:italic}.konami-overlay{z-index:9999;background:#000000f2;justify-content:center;align-items:center;animation:.3s konamiFadeIn;display:flex;position:fixed;inset:0}@keyframes konamiFadeIn{0%{opacity:0}to{opacity:1}}.konami-content{text-align:center;color:#0f0;max-width:500px;padding:20px;font-family:Courier New,monospace}.konami-content h1{margin-bottom:10px;font-size:24px;animation:.5s infinite alternate konamiGlow}@keyframes konamiGlow{0%{text-shadow:0 0 10px #0f0}to{text-shadow:0 0 20px #0f0,0 0 30px #0f0}}.konami-message{text-align:left;border:1px solid #0f0;margin:20px 0;padding:15px}.konami-message ul{margin:10px 0;padding-left:20px}.konami-hint{color:#666;margin-top:20px;font-size:12px}[data-terminal=true]{--bg:#0a0a0a;--text:#0f0;--text-gray:#0a0;--text-light:#080;--link:#0f0;--link-hover:#0a0;--border:#0f0;--border-dark:#0a0;--code-bg:#000;--card-bg:#050505}[data-terminal=true] body{background:#0a0a0a repeating-linear-gradient(0deg,#0000,#0000 2px,#00ff0008 2px 4px);font-family:Courier New,Courier,monospace}[data-terminal=true] .site-title:before{content:"> ";color:#0f0}[data-terminal=true] .post-item-title:before{content:"$ ";color:#0a0}[data-terminal=true] a{text-decoration:none}[data-terminal=true] a:hover{text-decoration:underline}.site{max-width:550px;margin:0 auto;padding:40px 20px}.site:has(.post-content-wrapper){max-width:850px}.site-header{margin-bottom:30px}.site-title{margin:0 0 8px;font-size:18px;font-weight:700}.site-links{margin-bottom:12px;font-size:13px}.site-links a{margin-right:12px}.site-nav{border-top:1px solid var(--border);padding-top:10px;font-size:13px}.site-nav a{color:var(--text-gray);margin-right:15px;text-decoration:none}.site-nav a:hover{color:var(--text)}.ascii-header{color:var(--text-gray);margin:0 0 10px;font-family:Courier New,monospace;font-size:8px;line-height:1.1;overflow:hidden}@media (max-width:500px){.ascii-header{font-size:5px}}.currently-widget{background:var(--card-bg);border:1px solid var(--border);flex:1;padding:12px;font-size:12px}.currently-widget h3{color:var(--text-gray);text-transform:uppercase;letter-spacing:1px;margin:0 0 8px;font-size:12px}.currently-widget ul{margin:0;padding:0;list-style:none}.currently-widget li{padding:3px 0}.currently-label{color:var(--text-gray)}.visitor-globe{background:var(--card-bg);border:1px solid var(--border);flex-direction:column;align-items:center;padding:12px;display:flex}.visitor-globe canvas{display:block}.globe-label{color:var(--text-gray);margin:8px 0 0;font-size:11px}.home-widgets{gap:15px;margin:20px 0;display:flex}@media (max-width:500px){.home-widgets{flex-direction:column}}.posts-heading{color:var(--text-gray);margin:0 0 15px;font-size:14px;font-weight:700}.posts{margin-top:30px}.post-item{margin-bottom:20px}.post-item-title{font-weight:700}.post-item-date{color:var(--text-gray);margin-left:8px;font-size:12px}.no-posts{color:var(--text-gray);font-style:italic}.post-back{margin-bottom:20px;font-size:13px;display:block}.post-title{margin:0 0 5px;font-size:16px;font-weight:700}.post-date{color:var(--text-gray);font-size:12px}.post-reading-time{color:var(--text-light);font-size:12px}.post-meta-row{flex-wrap:wrap;align-items:center;gap:15px;margin-bottom:20px;display:flex}.post-body{margin-top:20px}.post-body p{margin:15px 0}.post-body h1,.post-body h2,.post-body h3{margin:20px 0 10px;font-size:14px;font-weight:700}.post-body code{background:var(--code-bg);padding:2px 5px;font-family:Courier,monospace;font-size:13px}.post-body pre{background:var(--code-bg);padding:10px;font-family:Courier,monospace;font-size:13px;overflow-x:auto}.post-body pre code{background:0 0;padding:0}.post-body blockquote{border-left:2px solid var(--border-dark);color:var(--text-gray);margin:15px 0;padding-left:15px}.post-body ul,.post-body ol{margin:15px 0;padding-left:25px}.post-body li{margin:5px 0}.post-body img{max-width:100%}.post-body hr{border:none;border-top:1px solid var(--border);margin:25px 0}.post-footer-vote{border-top:1px solid var(--border);color:var(--text-gray);align-items:center;gap:15px;margin-top:40px;padding-top:20px;font-size:13px;display:flex}.view-count{color:var(--text-light);font-size:12px}.vote-container{align-items:center;gap:8px;font-size:13px;display:inline-flex}.vote-btn{border:1px solid var(--border-dark);cursor:pointer;color:var(--text-light);background:0 0;padding:4px 8px;font-family:inherit;font-size:10px;transition:all .15s}.vote-btn:hover:not(:disabled){border-color:var(--text-gray);color:var(--text-gray)}.vote-btn:disabled{cursor:default}.vote-btn.voted{border-color:var(--text-gray);color:var(--text)}.vote-up.voted{color:#2a6;border-color:#2a6}.vote-down.voted{color:#a33;border-color:#a33}.vote-score{text-align:center;min-width:24px;color:var(--text-gray);font-weight:700}.vote-score.positive{color:#2a6}.vote-score.negative{color:#a33}.comments-section{border-top:1px solid var(--border);margin-top:40px;padding-top:20px}.comments-section h3{margin:0 0 20px;font-size:14px;font-weight:700}.comment-form{margin-bottom:30px}.comment-name-input{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);width:200px;margin-bottom:10px;padding:8px;font-family:inherit;font-size:13px;display:block}.comment-content-input{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);resize:vertical;width:100%;min-height:80px;margin-bottom:10px;padding:8px;font-family:inherit;font-size:13px}.comment-name-input:focus,.comment-content-input:focus{border-color:var(--text-gray);outline:none}.comment-submit{background:var(--text);color:var(--bg);cursor:pointer;border:none;padding:8px 16px;font-family:inherit;font-size:13px}.comment-submit:hover:not(:disabled){opacity:.8}.comment-submit:disabled{opacity:.5;cursor:not-allowed}.comment-error{color:#c00;margin-bottom:10px;font-size:13px}.comments-list{margin-top:20px}.no-comments{color:var(--text-gray);font-size:13px;font-style:italic}.comment{border-bottom:1px solid var(--border);padding:15px 0}.comment:last-child{border-bottom:none}.comment-header{gap:10px;margin-bottom:8px;font-size:12px;display:flex}.comment-author{font-weight:700}.comment-date{color:var(--text-gray)}.comment-body{margin:0;font-size:13px;line-height:1.5}.static-page{margin-top:20px}.static-page h1{margin:0 0 10px;font-size:18px;font-weight:700}.static-page h2{margin:25px 0 10px;font-size:14px;font-weight:700}.static-page p{margin:15px 0}.static-page ul{margin:10px 0;padding-left:20px}.static-page li{margin:5px 0}.page-subtitle{color:var(--text-gray);margin-top:0}.experience-item{border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:15px}.experience-item:last-of-type{border-bottom:none}.experience-item h3{margin:0 0 5px;font-size:14px;font-weight:700}.experience-meta{color:var(--text-gray);margin:0 0 8px;font-size:13px}.experience-item p:last-child{margin-bottom:0}.projects-list{margin-top:20px}.project-card{background:var(--card-bg);border:1px solid var(--border);margin-bottom:15px;padding:15px}.project-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.project-card h3{margin:0;font-size:14px;font-weight:700}.project-status{color:var(--text-gray);font-size:12px}.project-card p{color:var(--text-gray);margin:0 0 10px;font-size:13px}.project-card a{font-size:13px}.project-tech{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.tech-tag{background:var(--code-bg);border:1px solid var(--border);color:var(--text-gray);padding:2px 8px;font-size:11px}.project-stars{color:var(--text-gray);font-size:12px}.section-note{color:var(--text-gray);margin-top:0;margin-bottom:15px;font-size:13px}.projects-footer{border-top:1px solid var(--border);color:var(--text-gray);margin-top:30px;padding-top:20px}.projects-footer p{margin:8px 0}.rec-section{margin-bottom:30px}.rec-list{padding:0;list-style:none}.rec-list li{border-bottom:1px solid var(--border);padding:8px 0}.rec-meta{color:var(--text-gray)}.rec-note{color:var(--text-gray);font-style:italic}.artist-tags{flex-wrap:wrap;gap:8px;margin:10px 0;display:flex}.artist-tag{background:var(--card-bg);border:1px solid var(--border);color:var(--text-gray);padding:4px 10px;font-size:12px}.links-section{margin-bottom:25px}.links-list{padding:0;list-style:none}.links-list li{padding:8px 0}.link-desc{color:var(--text-gray);font-size:13px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:20px;display:grid}.gallery-item{cursor:pointer;aspect-ratio:1;overflow:hidden}.gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .2s}.gallery-item:hover img{transform:scale(1.05)}.gallery-modal{z-index:1000;background:#000000e6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.gallery-modal-content{max-width:90%;max-height:90%;position:relative}.gallery-modal-content img{object-fit:contain;max-width:100%;max-height:80vh}.gallery-caption{color:#fff;text-align:center;margin-top:15px;font-size:14px}.gallery-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:24px;position:absolute;top:-40px;right:0}.login-container{max-width:350px;margin-top:30px}.login-container h1{margin:0 0 10px;font-size:16px;font-weight:700}.login-desc{color:var(--text-gray);margin:0 0 20px;font-size:13px}.login-form{margin-bottom:20px}.login-field{gap:10px;display:flex}.login-form input{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);flex:1;padding:8px 10px;font-family:inherit;font-size:14px}.login-form input:focus{border-color:var(--text-gray);outline:none}.login-form button{cursor:pointer;background:var(--text);color:var(--bg);border:1px solid var(--text);padding:8px 20px;font-family:inherit;font-size:14px}.login-form button:hover:not(:disabled){opacity:.8}.login-form button:disabled{opacity:.5;cursor:not-allowed}.login-error{color:#c00;margin-top:15px;font-size:13px}.login-hint{color:var(--text-light);font-size:11px;font-style:italic}.login-back{margin-top:20px;font-size:13px;display:block}.write-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.write-header h1{margin:0;font-size:16px;font-weight:700}.logout-btn{color:var(--text-gray);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:13px;text-decoration:underline}.logout-btn:hover{color:var(--text)}.write-form{margin-top:20px}.write-title-input{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);width:100%;margin-bottom:15px;padding:8px;font-family:inherit;font-size:14px;font-weight:700}.write-content-input{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);resize:vertical;width:100%;min-height:300px;padding:10px;font-family:inherit;font-size:14px;line-height:1.6}.write-title-input:focus,.write-content-input:focus{border-color:var(--text-gray);outline:none}.write-actions{justify-content:space-between;align-items:center;margin-top:15px;display:flex}.write-cancel{color:var(--text-gray);font-size:13px}.write-publish{cursor:pointer;background:var(--text);color:var(--bg);border:none;padding:8px 20px;font-family:inherit;font-size:14px}.write-publish:hover:not(:disabled){opacity:.8}.write-publish:disabled{opacity:.5;cursor:not-allowed}.write-error{color:#c00;margin-top:10px;font-size:13px}.write-success{color:#060;margin-top:10px;font-size:13px}.admin-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;display:flex}.admin-header h1{margin:0;font-size:16px;font-weight:700}.admin-actions{gap:15px;margin-bottom:30px;display:flex}.admin-new-btn{background:var(--text);color:var(--bg);padding:8px 16px;font-size:13px;text-decoration:none}.admin-new-btn:hover{opacity:.8;color:var(--bg)}.admin-view-btn{color:var(--text-gray);padding:8px 16px;font-size:13px}.admin-posts h2{margin:0 0 15px;font-size:14px;font-weight:700}.posts-table{border-collapse:collapse;width:100%;font-size:13px}.posts-table th{text-align:left;border-bottom:1px solid var(--border-dark);color:var(--text-gray);padding:8px 0;font-weight:400}.posts-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:10px 0}.posts-table .date-col{color:var(--text-gray);width:100px}.posts-table .actions-col{text-align:right;width:120px}.edit-link{margin-right:12px}.delete-btn{color:#c00;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;text-decoration:underline}.delete-btn:hover:not(:disabled){color:#900}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.loading{color:var(--text-gray)}.guestbook-ascii{margin-bottom:20px;font-size:6px;overflow-x:auto}.guestbook-ascii pre{color:var(--text-gray);margin:0;line-height:1.1}.guestbook-form{background:var(--card-bg);border:1px solid var(--border);margin-bottom:30px;padding:15px}.guestbook-name{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);width:200px;margin-bottom:10px;padding:8px;font-family:inherit;font-size:13px;display:block}.guestbook-message{border:1px solid var(--border-dark);background:var(--bg);color:var(--text);resize:vertical;width:100%;min-height:80px;margin-bottom:10px;padding:8px;font-family:inherit;font-size:13px}.guestbook-name:focus,.guestbook-message:focus{border-color:var(--text-gray);outline:none}.guestbook-submit{background:var(--text);color:var(--bg);cursor:pointer;border:none;padding:8px 20px;font-family:inherit;font-size:13px}.guestbook-submit:hover:not(:disabled){opacity:.8}.guestbook-submit:disabled{opacity:.5;cursor:not-allowed}.guestbook-error{color:#c00;margin-bottom:10px;font-size:13px}.guestbook-success{color:#0a0;margin-bottom:10px;font-size:13px}.guestbook-entries h2{margin:0 0 15px;font-size:14px;font-weight:700}.no-entries{color:var(--text-gray);font-style:italic}.guestbook-entry{border-bottom:1px solid var(--border);padding:15px 0}.guestbook-entry:last-child{border-bottom:none}.entry-header{justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.entry-name{font-weight:700}.entry-date{color:var(--text-gray)}.entry-message{margin:0;font-size:13px;line-height:1.5}.code-block-wrapper{border:1px solid var(--border);border-radius:4px;margin:20px 0;overflow:hidden}.code-block-header{background:var(--code-bg);border-bottom:1px solid var(--border);color:var(--text-gray);padding:8px 12px;font-size:12px}.code-filename{font-family:monospace}.code-block-container{position:relative}.code-copy-button{z-index:10;background:var(--bg);border:1px solid var(--border-dark);cursor:pointer;color:var(--text);border-radius:3px;padding:4px 8px;font-family:inherit;font-size:11px;transition:all .2s;position:absolute;top:10px;right:10px}.code-copy-button:hover{background:var(--card-bg);border-color:var(--text-gray)}.interactive-demo{border:1px solid var(--border);border-radius:4px;margin:20px 0;overflow:hidden}.demo-title{background:var(--card-bg);border-bottom:1px solid var(--border);margin:0 0 10px;padding:12px;font-size:14px;font-weight:700}.demo-tabs{background:var(--code-bg);border-bottom:1px solid var(--border);display:flex}.demo-tab{border:none;border-right:1px solid var(--border);cursor:pointer;color:var(--text-gray);background:0 0;padding:8px 16px;font-family:inherit;font-size:13px;transition:all .2s}.demo-tab:last-child{border-right:none}.demo-tab:hover{background:var(--card-bg);color:var(--text)}.demo-tab.active{background:var(--bg);color:var(--text);font-weight:700}.demo-preview{background:var(--bg);min-height:300px;position:relative}.demo-iframe{border:none;width:100%;height:400px;display:block}.demo-code{background:var(--code-bg);max-height:500px;padding:15px;overflow-y:auto}.demo-code-section{margin-bottom:20px}.demo-code-section:last-child{margin-bottom:0}.demo-code-label{text-transform:uppercase;color:var(--text-gray);margin-bottom:8px;font-size:11px;font-weight:700}.demo-code pre{background:var(--bg);border:1px solid var(--border);border-radius:3px;margin:0;padding:12px;overflow-x:auto}.demo-code code{color:var(--text);font-family:Courier New,monospace;font-size:12px}.project-timeline{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;margin:30px 0;padding:20px}.timeline-title{margin:0 0 20px;font-size:16px;font-weight:700}.timeline-container{padding-left:30px;position:relative}.timeline-container:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:8px}.timeline-item{margin-bottom:30px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-marker{background:var(--text);border:2px solid var(--bg);z-index:1;border-radius:50%;width:12px;height:12px;position:absolute;top:5px;left:-22px}.timeline-content{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:15px}.timeline-date{color:var(--text-gray);margin-bottom:5px;font-size:12px}.timeline-project-name{margin:0 0 8px;font-size:14px;font-weight:700}.timeline-description{color:var(--text-gray);margin:0 0 10px;font-size:13px}.timeline-category{background:var(--code-bg);border:1px solid var(--border);color:var(--text-gray);border-radius:3px;padding:3px 8px;font-size:11px;display:inline-block}.skills-chart{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;margin:30px 0;padding:20px}.skills-title{margin:0 0 20px;font-size:16px;font-weight:700}.skills-legend{border-top:1px solid var(--border);margin-top:20px;padding-top:20px}.skills-category{margin-bottom:15px}.skills-category:last-child{margin-bottom:0}.skills-category-name{color:var(--text);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.skills-category-items{flex-wrap:wrap;gap:6px;display:flex}.skills-tag{background:var(--code-bg);border:1px solid var(--border);color:var(--text-gray);border-radius:3px;padding:4px 10px;font-size:11px}.share-buttons{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;flex-wrap:wrap;align-items:center;gap:10px;margin:30px 0;padding:15px;display:flex}.share-label{color:var(--text-gray);margin-right:5px;font-size:13px}.share-button{background:var(--bg);border:1px solid var(--border-dark);color:var(--text);cursor:pointer;border-radius:3px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:12px;text-decoration:none;transition:all .2s;display:flex}.share-button:hover{background:var(--card-bg);border-color:var(--text-gray);color:var(--text)}.share-button svg{font-size:14px}.reading-progress-container{z-index:1000;pointer-events:none;background:0 0;height:3px;position:fixed;top:0;left:0;right:0}.reading-progress-bar{background:var(--text);height:100%;transition:width .1s ease-out}.post-content-wrapper{grid-template-columns:1fr 250px;gap:30px;margin-top:20px;display:grid}@media (max-width:800px){.post-content-wrapper{grid-template-columns:1fr}.table-of-contents{order:-1}}.table-of-contents{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;align-self:start;max-height:calc(100vh - 40px);padding:15px;position:sticky;top:20px;overflow-y:auto}.toc-title{margin:0 0 15px;font-size:14px;font-weight:700}.toc-nav{flex-direction:column;gap:6px;display:flex}.toc-link{color:var(--text-gray);padding:4px 0;font-size:12px;line-height:1.4;text-decoration:none;transition:color .2s}.toc-link:hover{color:var(--text)}.toc-level-1{color:var(--text);font-weight:700}.toc-level-2{padding-left:12px}.toc-level-3{padding-left:24px;font-size:11px}.toc-link.active{color:var(--text);font-weight:700}.comment-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;display:flex}.comment-action-btn{border:1px solid var(--border-dark);color:var(--text-gray);cursor:pointer;background:0 0;border-radius:3px;align-items:center;gap:4px;padding:4px 8px;font-family:inherit;font-size:11px;transition:all .2s;display:flex}.comment-action-btn:hover{border-color:var(--text-gray);color:var(--text)}.comment-action-btn svg{font-size:12px}.comment-reply{border-top:1px solid var(--border);margin-top:15px;padding-top:15px}.reactions-picker{background:var(--card-bg);border:1px solid var(--border);z-index:10;border-radius:4px;gap:5px;margin-top:5px;padding:8px;display:flex;position:absolute}.reaction-btn{background:var(--bg);border:1px solid var(--border-dark);cursor:pointer;border-radius:3px;padding:4px 8px;font-family:inherit;font-size:14px;transition:all .2s}.reaction-btn:hover{background:var(--card-bg);border-color:var(--text-gray)}.comment-reactions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.reaction-badge{background:var(--code-bg);border:1px solid var(--border);color:var(--text-gray);border-radius:3px;padding:3px 8px;font-size:12px}.reply-form{background:var(--code-bg);border:1px solid var(--border);border-radius:4px;margin-top:15px;padding:15px}.reply-actions{gap:10px;margin-top:10px;display:flex}.comment-cancel{border:1px solid var(--border-dark);color:var(--text-gray);cursor:pointer;background:0 0;border-radius:3px;padding:6px 12px;font-family:inherit;font-size:12px;transition:all .2s}.comment-cancel:hover{border-color:var(--text-gray);color:var(--text)}.comment-replies{border-left:2px solid var(--border);margin-top:15px;padding-left:20px}.post-audio-player{background:var(--card-bg);border:1px solid var(--border);border-radius:6px;margin:20px 0;padding:15px}.audio-player-content{flex-direction:column;gap:12px;display:flex}.audio-label{color:var(--text-gray);align-items:center;gap:8px;font-size:12px;display:flex}.audio-icon{font-size:16px}.audio-controls{align-items:center;gap:12px;display:flex}.audio-play-btn{border:1px solid var(--border-dark);background:var(--bg);width:36px;height:36px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.audio-play-btn:hover:not(:disabled){background:var(--border)}.audio-play-btn:disabled{opacity:.5;cursor:not-allowed}.audio-progress{flex:1}.audio-slider{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;width:100%;height:4px}.audio-slider::-webkit-slider-thumb{appearance:none;background:var(--text);cursor:pointer;border-radius:50%;width:12px;height:12px}.audio-slider::-moz-range-thumb{background:var(--text);cursor:pointer;border:none;border-radius:50%;width:12px;height:12px}.audio-time{color:var(--text-gray);text-align:right;min-width:80px;font-family:monospace;font-size:11px}.audio-upload-section{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;margin:15px 0;padding:15px}.audio-upload-label{color:var(--text-gray);align-items:center;gap:8px;margin-bottom:12px;font-size:13px;display:flex}.audio-upload-icon{font-size:16px}.audio-upload-input input[type=file]{display:none}.audio-upload-btn{background:var(--bg);border:1px solid var(--border-dark);color:var(--text);cursor:pointer;border-radius:4px;padding:8px 16px;font-size:13px;transition:all .2s;display:inline-block}.audio-upload-btn:hover{background:var(--border)}.audio-preview{flex-direction:column;gap:10px;display:flex}.audio-file-name{color:var(--text-gray);font-size:12px}.audio-preview-player{width:100%;height:32px}.audio-remove-btn{border:1px solid var(--border);color:var(--text-gray);cursor:pointer;background:0 0;border-radius:3px;align-self:flex-start;padding:4px 10px;font-size:12px;transition:all .2s}.audio-remove-btn:hover{color:#f44;border-color:#f44}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
