@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700&family=Space+Grotesk:wght@500;700&display=swap";.latest-updates-section{width:100%;margin-bottom:6rem;margin-top:15vh}.section-title{font-size:2rem;font-weight:700;margin-bottom:4rem;color:var(--primary);text-align:left;letter-spacing:-.02em}.timeline-container{display:flex;flex-direction:column;width:100%;position:relative}.timeline-mobile-date{display:none}.timeline-item{display:grid;grid-template-columns:140px 60px 1fr;gap:0;min-height:150px;position:relative}.timeline-date{text-align:right;font-family:Space Mono,monospace;color:var(--secondary);font-size:.8rem;padding-top:.3rem;opacity:.7}.timeline-connector{display:flex;flex-direction:column;align-items:center;position:relative;height:100%}.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--border-color);z-index:2;margin-top:.4rem;transition:all .3s ease}.timeline-line{width:2px;background:var(--border-color);flex-grow:1;position:absolute;top:14px;bottom:-150px;left:50%;transform:translate(-50%);z-index:1}.timeline-item:last-child .timeline-line{display:none}.pulse-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 #83854d66;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%{transform:scale(.95);box-shadow:0 0 #83854db3}70%{transform:scale(1);box-shadow:0 0 0 8px #83854d00}to{transform:scale(.95);box-shadow:0 0 #83854d00}}.timeline-content-card{display:block;text-decoration:none;padding-bottom:5rem;padding-left:2rem;transition:transform .3s ease}.timeline-content-card:hover{transform:translate(10px)}.timeline-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.project-badge{display:inline-block;padding:5px 14px;border-radius:999px;background-color:var(--background);border:1px solid var(--border-color);font-size:.75rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.timeline-item:hover .timeline-dot{border-color:var(--accent);background-color:var(--accent)}.arrow-icon{font-size:1.1rem;color:var(--secondary);opacity:0;transform:translate(-10px);transition:all .3s ease}.timeline-content-card:hover .arrow-icon{opacity:1;transform:translate(0);color:var(--accent)}.timeline-title{font-size:1.5rem;font-weight:700;color:var(--primary);margin:0 0 .75rem;line-height:1.2}.timeline-description{font-size:1rem;line-height:1.6;color:var(--secondary);max-width:800px;margin:0}@media (max-width: 768px){.latest-updates-section{margin-top:10vh;margin-bottom:2.5rem}.section-title{font-size:1.4rem;margin-bottom:1.75rem}.timeline-item{grid-template-columns:28px 1fr;gap:0;min-height:auto;padding-bottom:0}.timeline-date{display:none}.timeline-connector{padding-top:.15rem}.timeline-content-card{padding-left:.75rem;padding-bottom:2rem}.timeline-content-card:hover{transform:none}.timeline-header{flex-direction:row;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem}.timeline-mobile-date{display:block;font-family:Space Mono,monospace;font-size:.7rem;color:var(--secondary);opacity:.7;margin-bottom:.25rem}.timeline-title{font-size:1.1rem;margin-bottom:.4rem;line-height:1.3}.timeline-description{font-size:.85rem;line-height:1.5}.project-badge{font-size:.6rem;padding:3px 10px;letter-spacing:.03em}.arrow-icon{display:none}.timeline-line{bottom:-20px}.timeline-dot{width:10px;height:10px;margin-top:.35rem}}@media (max-width: 480px){.latest-updates-section{margin-top:8vh}.section-title{font-size:1.25rem;margin-bottom:1.25rem}.timeline-item{grid-template-columns:22px 1fr}.timeline-content-card{padding-left:.6rem;padding-bottom:1.5rem}.timeline-dot{width:8px;height:8px}.timeline-title{font-size:1rem}.timeline-description{font-size:.8rem;line-height:1.45}.project-badge{font-size:.55rem;padding:2px 8px}}.heatmap-section{width:100%;margin:1rem 0}.heatmap-title{font-size:1rem;font-weight:600;color:var(--secondary);margin-bottom:1rem;letter-spacing:.02em}.heatmap-wrapper{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}.heatmap-day-labels{display:grid;grid-template-rows:repeat(7,1fr);gap:3px;padding-top:20px}.heatmap-day-label{font-size:.6rem;color:var(--secondary);opacity:.6;height:13px;display:flex;align-items:center;font-family:Space Mono,monospace}.heatmap-grid-container{flex:1;min-width:0}.heatmap-month-labels{display:grid;height:20px;margin-bottom:2px}.heatmap-month-label{font-size:.6rem;color:var(--secondary);opacity:.6;font-family:Space Mono,monospace}.heatmap-grid{display:grid;grid-template-rows:repeat(7,1fr);grid-auto-flow:column;gap:3px}.heatmap-cell{width:13px;height:13px;border-radius:2px;transition:all .15s ease;cursor:default}.heatmap-cell:hover{transform:scale(1.3);outline:1px solid var(--secondary);outline-offset:1px}.heatmap-cell.level-0{background-color:var(--border-color)}.heatmap-cell.level-1{background-color:#83854d4d}.heatmap-cell.level-2{background-color:#83854d99}.heatmap-cell.level-3{background-color:var(--accent)}[data-theme=dark] .heatmap-cell.level-0{background-color:#1e1e1e}[data-theme=dark] .heatmap-cell.level-1{background-color:#a3a56a40}[data-theme=dark] .heatmap-cell.level-2{background-color:#a3a56a80}[data-theme=dark] .heatmap-cell.level-3{background-color:var(--accent)}.heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:.75rem;justify-content:flex-end}.heatmap-legend .heatmap-cell{width:11px;height:11px}.heatmap-legend .heatmap-cell:hover{transform:none;outline:none}.heatmap-legend-label{font-size:.6rem;color:var(--secondary);opacity:.6;font-family:Space Mono,monospace}@media (max-width: 768px){.heatmap-cell{width:10px;height:10px}.heatmap-grid{gap:2px}.heatmap-day-labels{gap:2px;padding-top:18px}.heatmap-day-label{height:10px;font-size:.5rem}.heatmap-legend .heatmap-cell{width:9px;height:9px}}@media (max-width: 480px){.heatmap-cell{width:8px;height:8px}.heatmap-grid{gap:2px}.heatmap-day-labels{gap:2px;padding-top:16px}.heatmap-day-label{height:8px}}.terminal-section{width:100%;margin:2rem 0}.terminal-window{background:#1a1a2e;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #00000040;border:1px solid rgba(255,255,255,.06);cursor:text}.terminal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#16162a;border-bottom:1px solid rgba(255,255,255,.05)}.terminal-dots{display:flex;gap:6px}.terminal-dot{width:12px;height:12px;border-radius:50%;background:#3a3a5c}.terminal-dot.red{background:#ff5f57}.terminal-dot.yellow{background:#ffbd2e}.terminal-dot.green{background:#28c840}.terminal-title{font-family:JetBrains Mono,Space Mono,monospace;font-size:.75rem;color:#fff6}.terminal-body{padding:1.25rem;min-height:280px;max-height:400px;overflow-y:auto;font-family:JetBrains Mono,Space Mono,monospace;font-size:.85rem;line-height:1.6}.terminal-body::-webkit-scrollbar{width:6px}.terminal-body::-webkit-scrollbar-track{background:transparent}.terminal-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.terminal-line{white-space:pre-wrap;word-break:break-word}.terminal-line.input{color:#e0e0e0}.terminal-line.output{color:#ffffffb3}.terminal-line.error{color:#ff6b6b}.terminal-line.ascii{color:var(--accent);font-size:.65rem;line-height:1.2;opacity:.8}.terminal-prompt{color:var(--accent);margin-right:.25rem;-webkit-user-select:none;user-select:none}.terminal-input-line{display:flex;align-items:center}.terminal-input{flex:1;background:transparent;border:none;outline:none;color:#e0e0e0;font-family:JetBrains Mono,Space Mono,monospace;font-size:.85rem;caret-color:var(--accent);padding:0}.terminal-cursor{width:8px;height:1.1em;background:var(--accent);opacity:.7;animation:blink-cursor 1s step-end infinite;margin-left:1px}@keyframes blink-cursor{0%,to{opacity:.7}50%{opacity:0}}@media (max-width: 768px){.terminal-window{border-radius:10px}.terminal-body{padding:1rem;min-height:220px;max-height:320px;font-size:.75rem}.terminal-dot{width:10px;height:10px}.terminal-title{font-size:.65rem}.terminal-line.ascii{font-size:.5rem}.terminal-input{font-size:.75rem}}@media (max-width: 480px){.terminal-body{font-size:.7rem;padding:.75rem;min-height:200px;max-height:280px}.terminal-line.ascii{font-size:.45rem}}.home-container{display:flex;flex-direction:column;align-items:center;padding:4rem;max-width:1200px;margin:0 auto}.social-header{position:absolute;top:1rem;right:4rem;display:flex;flex-direction:column;gap:.5rem;z-index:10}.social-header a{color:var(--secondary);font-size:1.5rem;transition:color .3s ease}.social-header a:hover{color:var(--primary)}.main-content{display:flex;flex-direction:column;width:100%;padding-right:4rem;gap:4rem}.title-section{text-align:left;margin:4rem 0}.title-section h1{font-size:2.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--primary)}.title-section p{font-size:1.1rem;color:var(--secondary);max-width:600px}.my-projects-section{width:100%;padding:2rem 0;background:transparent}.my-projects-section h2{font-size:2rem;font-weight:700;margin-bottom:3rem;color:var(--primary);font-family:Space Grotesk,sans-serif}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.gap-6{gap:1.5rem}.max-w-7xl{max-width:80rem}.mx-auto{margin-left:auto;margin-right:auto}.px-4{padding-left:1rem;padding-right:1rem}.h-full{height:100%}.h-64{height:16rem}.w-full{width:100%}.relative{position:relative}.absolute{position:absolute}.flex{display:flex}.flex-col{flex-direction:column}.flex-grow{flex-grow:1}.items-center{align-items:center}.mb-3{margin-bottom:.75rem}.mb-6{margin-bottom:1.5rem}.mt-auto{margin-top:auto}.ml-auto{margin-left:auto}.pt-4{padding-top:1rem}.p-8{padding:2rem}.inset-0{top:0;right:0;bottom:0;left:0}.-inset-px{top:-1px;right:-1px;bottom:-1px;left:-1px}.rounded-3xl{border-radius:1.5rem}.rounded-t-3xl{border-top-left-radius:1.5rem;border-top-right-radius:1.5rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-t{border-top-width:1px}.bg-white{background-color:var(--card-bg)}.bg-gray-50,.bg-neutral-100{background-color:var(--image-bg)}.border-gray-100,.border-gray-200{border-color:var(--card-border)}.text-primary{color:var(--primary)}.text-secondary{color:var(--secondary)}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-gray-900{color:#111827}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-white{--tw-gradient-from: var(--gradient-base);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, rgba(255, 255, 255, 0))}.to-transparent{--tw-gradient-to: transparent}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-80{opacity:.8}.shadow-sm{box-shadow:0 1px 2px 0 var(--card-hover-shadow)}.shadow-md{box-shadow:0 4px 6px -1px var(--card-hover-shadow),0 2px 4px -1px var(--card-hover-shadow)}.group:hover .group-hover\:scale-\[1\.01\]{transform:scale(1.01)}.group:hover .group-hover\:scale-110{transform:scale(1.1)}.group:hover .group-hover\:translate-x-1{transform:translate(.25rem)}.group:hover .group-hover\:opacity-100{opacity:1}.transition{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.overflow-hidden{overflow:hidden}.object-cover{object-fit:cover}.pointer-events-none{pointer-events:none}.cursor-pointer{cursor:pointer}.text-2xl{font-size:1.5rem;line-height:2rem}.font-bold{font-weight:700}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.tracking-tight{letter-spacing:-.025em}.bg-accent-light{background-color:var(--chip-bg)}.text-accent-dark{color:var(--accent-hover)}.ring-1{box-shadow:inset 0 0 0 1px var(--tw-ring-color)}.ring-accent{--tw-ring-color: rgba(131, 133, 77, .2)}.w-fit{width:fit-content}.gap-1{gap:.25rem}.gap-3{gap:.75rem}.w-2{width:.5rem}.h-2{height:.5rem}.bg-accent{background-color:var(--accent)}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:col-span-2{grid-column:span 2 / span 2}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px var(--card-hover-shadow),0 2px 4px -1px var(--card-hover-shadow)}.transform{transform:translate(0)}.inline-flex{display:inline-flex}.block{display:block}.group{position:relative}.ring-inset{--tw-ring-inset: inset}.font-medium{font-weight:500}.font-sans{font-family:var(--font-primary)}.leading-relaxed{line-height:1.625}@media (max-width: 768px){.home-container{padding:1.5rem 1rem}.social-header{position:relative;top:auto;right:auto;flex-direction:row;gap:1.5rem;justify-content:center;margin-bottom:.5rem}.social-header a{font-size:1.4rem;padding:.5rem;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.main-content{padding-right:0;gap:2rem}.title-section{margin:1rem 0;text-align:left}.title-section h1{font-size:1.85rem;margin-bottom:1rem}.title-section p{font-size:.95rem;max-width:100%;line-height:1.65}.my-projects-section{padding:0}.my-projects-section h2{font-size:1.5rem;margin-bottom:1.5rem}.px-4{padding-left:0;padding-right:0}.gap-6{gap:1rem}.p-8{padding:1.25rem}.text-2xl{font-size:1.15rem;line-height:1.5rem}.h-64{height:200px}.md\:col-span-2{grid-column:span 1 / span 1}.rounded-3xl{border-radius:1rem}.rounded-t-3xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.text-xs{font-size:.7rem}.text-sm{font-size:.8rem;line-height:1.2rem}.group:hover .group-hover\:scale-\[1\.01\],.group:hover .group-hover\:scale-110{transform:none}}@media (max-width: 480px){.home-container{padding:1rem .75rem}.title-section h1{font-size:1.65rem}.title-section p{font-size:.9rem}.p-8{padding:1rem}.text-2xl{font-size:1.05rem;line-height:1.4rem}.h-64{height:180px}.gap-6{gap:.85rem}}@media (max-width: 360px){.home-container{padding:.75rem .5rem}.title-section h1{font-size:1.5rem}.h-64{height:160px}}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease;padding:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-content{position:relative;background-color:var(--surface);padding:2rem;border-radius:8px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}.lightbox-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:4px}.lightbox-description{margin-top:1rem;color:var(--primary);text-align:center;max-width:60ch}.lightbox-close{position:absolute;top:10px;right:15px;background:none;border:none;color:var(--primary);font-size:2.5rem;cursor:pointer;line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.lightbox-overlay{padding:.5rem}.lightbox-content{padding:2.5rem 1rem 1rem;max-width:98vw;max-height:90vh;border-radius:12px}.lightbox-image{max-height:65vh;border-radius:6px}.lightbox-description{font-size:.85rem;max-width:100%;margin-top:.75rem}.lightbox-close{top:4px;right:4px;font-size:2rem}}@media (max-width: 480px){.lightbox-content{padding:2.25rem .75rem .75rem}.lightbox-image{max-height:55vh}}.project-detail{min-height:100vh;background-color:#000;color:#fff;padding:8rem 2rem}.project-detail-container{max-width:1000px;margin:0 auto}.project-detail h1{font-family:Inter,sans-serif;font-size:48px;font-weight:700;margin-bottom:5rem;letter-spacing:-.02em}.project-section{margin-bottom:8rem}.project-section h2{font-size:32px;font-weight:600;margin-bottom:3rem;color:#fff}.project-section p{font-size:18px;line-height:1.6;color:#fffc;margin-bottom:2rem}.tech-stack{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem}.tech-item{background:#1a1a1a;padding:1.5rem;border-radius:12px;transition:transform .3s ease}.tech-item:hover{transform:translateY(-5px)}.tech-item h3{font-size:20px;font-weight:600;margin-bottom:1.5rem;color:#fff}.tech-item p{font-size:16px;margin-bottom:0}.development-steps{display:grid;gap:3rem}.step{background:#1a1a1a;padding:2.5rem;border-radius:12px;position:relative}.step h3{font-size:20px;font-weight:600;margin-bottom:1.5rem;color:#fff}.features-list{list-style:none;padding:0}.features-list li{font-size:18px;margin-bottom:1.5rem;padding-left:2rem;position:relative}.features-list li:before{content:"•";position:absolute;left:0;color:#fff}.project-links{display:flex;gap:2rem}.github-link,.demo-link{display:inline-block;padding:1rem 2rem;border-radius:8px;font-size:16px;font-weight:500;text-decoration:none;transition:all .3s ease}.github-link{background:transparent;border:1px solid #fff;color:#fff}.demo-link{background:#fff;color:#000}.github-link:hover,.demo-link:hover{transform:translateY(-3px)}.project-detail-page{padding-top:40px;padding-bottom:100px;max-width:900px;margin:0 auto}.project-detail-page.not-found{text-align:center}.project-navigation{display:flex;justify-content:space-between;align-items:center;margin-bottom:6rem}.back-button{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--font-secondary);color:var(--secondary);font-weight:700;padding:.5rem 0;min-height:44px}.back-button:hover{color:var(--primary)}.visit-project-button{display:inline-flex;align-items:center;padding:.5rem 1rem;background-color:var(--primary);color:var(--background);text-decoration:none;border-radius:4px;font-weight:700;font-size:.9rem;transition:all .2s ease;min-height:44px}.visit-project-button:hover{opacity:.85;color:var(--background);transform:translateY(-1px)}.project-header{text-align:center;margin-bottom:5rem;padding-bottom:4rem;border-bottom:1px solid var(--border-color);position:relative}.project-status-indicator{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--secondary);margin-bottom:1.5rem;padding:.25rem .75rem;border-radius:999px;background-color:var(--surface);border:1px solid var(--border-color)}.status-dot{width:8px;height:8px;border-radius:50%}.status-active-development .status-dot{background-color:#ff6b6b;animation:pulse-status 2s infinite}.status-completed .status-dot{background-color:#51cf66}.status-on-hold .status-dot{background-color:#fcc419}@keyframes pulse-status{0%{box-shadow:0 0 #ff6b6bb3}70%{box-shadow:0 0 0 10px #ff6b6b00}to{box-shadow:0 0 #ff6b6b00}}.project-title-main{font-size:3.5rem;margin-bottom:1.5rem;color:var(--primary);margin:0}.project-tagline{font-size:1.2rem;color:var(--secondary);margin-bottom:6rem}.tech-tags-container{display:flex;justify-content:center;flex-wrap:wrap;gap:1.5rem}.tech-tag{background-color:var(--border-color);color:var(--secondary);padding:calc(var(--spacing-unit) * .5) var(--spacing-unit);border-radius:4px;font-size:.8rem}.project-main-content{font-size:1.1rem;line-height:1.7;color:var(--secondary);padding-bottom:6rem;border-bottom:1px solid var(--border-color)}.updates-history{margin-top:6rem;padding-top:2rem}.updates-history-title{text-align:center;margin-bottom:5rem;font-size:2.5rem}.update-entry{background-color:var(--surface);border:1px solid var(--border-color);border-radius:8px;padding:3rem;margin-bottom:4rem}.update-entry-image{width:100%;height:auto;max-height:400px;object-fit:cover;border-radius:8px;margin-bottom:2rem}.update-entry-date{display:block;font-size:.8rem;color:var(--secondary);margin-bottom:1rem}.update-entry-title{font-size:1.25rem;margin-bottom:1.5rem}.update-entry-text{font-size:1rem;line-height:1.6;color:var(--secondary)}.project-documentation h1{font-size:2.8rem;font-weight:700;line-height:1.3;margin-bottom:2rem}.project-gallery{margin-bottom:8rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:2rem}.gallery-image{width:100%;height:auto;border-radius:4px;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out;cursor:pointer}.gallery-image:hover{transform:scale(1.03);box-shadow:0 8px 20px #0000001a}.gallery-locked{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:280px;border:2px dashed var(--border-color);border-radius:12px;background:repeating-linear-gradient(-45deg,transparent,transparent 10px,rgba(0,0,0,.02) 10px,rgba(0,0,0,.02) 20px);text-align:center;padding:3rem}.gallery-locked-icon{margin-bottom:1.5rem;color:var(--secondary);opacity:.4}.gallery-locked-text{font-size:1.2rem;font-weight:600;color:var(--primary);margin-bottom:.5rem}.gallery-locked-subtext{font-size:.95rem;color:var(--secondary);opacity:.7}@media (max-width: 768px){.project-detail{padding:4rem 1rem}.project-detail h1{font-size:28px}.project-section{margin-bottom:4rem}.project-section h2{font-size:22px;margin-bottom:1.5rem}.project-section p{font-size:16px}.tech-stack{grid-template-columns:1fr;gap:1.5rem}.step{padding:1.5rem}.project-links{flex-direction:column}.project-detail-page{padding-top:16px;padding-bottom:60px;padding-left:.5rem;padding-right:.5rem}.project-navigation{flex-direction:row;gap:.75rem;margin-bottom:2rem;padding:0 .25rem}.back-button{font-size:.9rem}.visit-project-button{font-size:.8rem;padding:.4rem .8rem}.project-header{margin-bottom:2rem;padding-bottom:1.5rem}.project-title-main{font-size:1.85rem;line-height:1.15;margin-bottom:.75rem}.project-tagline{font-size:.95rem;margin-bottom:1.5rem;line-height:1.5;padding:0 .5rem}.project-status-indicator{font-size:.8rem;margin-bottom:1rem}.tech-tags-container{gap:.5rem;padding:0 .25rem}.tech-tag{font-size:.7rem;padding:.2rem .5rem}.project-main-content{font-size:.95rem;line-height:1.65;padding-bottom:2rem;padding-left:.25rem;padding-right:.25rem}.updates-history{margin-top:2.5rem}.updates-history-title{font-size:1.5rem;margin-bottom:2rem}.update-entry{padding:1.25rem;margin-bottom:1.5rem;border-radius:8px}.update-entry-image{max-height:220px;margin-bottom:1rem;border-radius:6px}.update-entry-title{font-size:1.05rem;margin-bottom:.75rem}.update-entry-text{font-size:.9rem;line-height:1.55}.update-entry-date{font-size:.75rem;margin-bottom:.5rem}.project-gallery{margin-bottom:3rem}.gallery-grid{grid-template-columns:1fr 1fr;gap:.75rem}.gallery-image:hover{transform:none}.gallery-locked{min-height:180px;padding:1.5rem;border-radius:8px}.gallery-locked-icon svg{width:36px;height:36px}.gallery-locked-text{font-size:1rem}.gallery-locked-subtext{font-size:.85rem}.project-documentation h1{font-size:1.75rem}}@media (max-width: 480px){.project-detail{padding:3rem .75rem}.project-detail h1{font-size:24px}.project-detail-page{padding-top:12px;padding-bottom:48px}.project-title-main{font-size:1.6rem}.project-tagline{font-size:.9rem;margin-bottom:1.25rem}.tech-tag{font-size:.65rem;padding:.15rem .4rem}.update-entry{padding:1rem}.update-entry-title{font-size:1rem}.update-entry-text{font-size:.85rem}.gallery-grid{grid-template-columns:1fr 1fr;gap:.5rem}.project-documentation h1{font-size:1.5rem}}@media (max-width: 360px){.project-title-main{font-size:1.45rem}.project-tagline{font-size:.85rem}.tech-tags-container{gap:.4rem}.update-entry{padding:.85rem;margin-bottom:1rem}}.reading-progress-container{position:fixed;top:0;left:0;width:100%;height:2px;background:transparent;z-index:999;pointer-events:none}.reading-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));transform-origin:left;transform:scaleX(0);transition:transform .1s linear;will-change:transform}.cmd-k-hint{position:fixed;bottom:2rem;left:2rem;display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border-color);border-radius:8px;padding:6px 10px;cursor:pointer;z-index:999;transition:all .2s ease;box-shadow:0 2px 8px #0000000f}.cmd-k-hint:hover{border-color:var(--secondary);box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.cmd-k-hint-key{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;background:var(--background);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;font-family:var(--font-secondary);font-weight:600;color:var(--secondary);padding:0 4px}.cmd-palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:flex-start;padding-top:20vh;z-index:9999;animation:cmd-fade-in .15s ease}@keyframes cmd-fade-in{0%{opacity:0}to{opacity:1}}.cmd-palette{width:100%;max-width:560px;background:var(--surface);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 20px 60px #0003;overflow:hidden;animation:cmd-slide-in .15s ease}@keyframes cmd-slide-in{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.cmd-palette-input-wrapper{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.cmd-palette-search-icon{flex-shrink:0;color:var(--secondary);opacity:.5}.cmd-palette-input{flex:1;border:none;outline:none;background:transparent;font-size:1rem;font-family:var(--font-primary);color:var(--primary)}.cmd-palette-input::placeholder{color:var(--secondary);opacity:.5}.cmd-palette-esc{font-size:.6rem;font-family:var(--font-secondary);color:var(--secondary);background:var(--background);border:1px solid var(--border-color);border-radius:4px;padding:2px 6px;opacity:.6}.cmd-palette-results{max-height:360px;overflow-y:auto;padding:.5rem 0}.cmd-palette-group{padding:.25rem 0}.cmd-palette-group-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--secondary);opacity:.5;padding:.5rem 1.25rem .25rem}.cmd-palette-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem 1.25rem;border:none;background:transparent;cursor:pointer;font-size:.9rem;font-family:var(--font-primary);color:var(--primary);text-align:left;transition:background-color .1s ease}.cmd-palette-item:hover,.cmd-palette-item.selected{background-color:var(--chip-bg)}.cmd-palette-item-icon{font-size:1rem;flex-shrink:0;width:24px;text-align:center}.cmd-palette-item-label{flex:1}.cmd-palette-item-enter{font-size:.75rem;color:var(--secondary);opacity:.4}.cmd-palette-empty{text-align:center;padding:2rem;color:var(--secondary);opacity:.5;font-size:.9rem}@media (max-width: 768px){.cmd-k-hint{bottom:1.25rem;left:1.25rem}.cmd-palette-overlay{padding-top:10vh;padding-left:.75rem;padding-right:.75rem}.cmd-palette{max-width:100%;border-radius:10px}.cmd-palette-results{max-height:50vh}}@supports (padding: env(safe-area-inset-bottom)){.cmd-k-hint{bottom:calc(1.25rem + env(safe-area-inset-bottom));left:calc(1.25rem + env(safe-area-inset-left))}}:root{--background: #fffffe;--surface: #ffffff;--primary: #2c2c2c;--secondary: #5a5a5a;--accent: #83854D;--accent-hover: #785C40;--border-color: #eeeeee;--card-bg: #ffffff;--card-border: #e5e7eb;--card-hover-shadow: rgba(0, 0, 0, .1);--spotlight-color: rgba(0, 0, 0, .03);--image-bg: #f9fafb;--chip-bg: rgba(131, 133, 77, .1);--gradient-base: #ffffff;--font-primary: "Inter", sans-serif;--font-secondary: "Space Grotesk", sans-serif;--spacing-unit: 8px}[data-theme=dark]{--background: #111111;--surface: #1a1a1a;--primary: #f0f0f0;--secondary: #a0a0a0;--accent: #a3a56a;--accent-hover: #c4b896;--border-color: #2a2a2a;--card-bg: #1a1a1a;--card-border: #2a2a2a;--card-hover-shadow: rgba(0, 0, 0, .5);--spotlight-color: rgba(255, 255, 255, .04);--image-bg: #242424;--chip-bg: rgba(163, 165, 106, .15);--gradient-base: #1a1a1a}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font-primary);background-color:var(--background);color:var(--primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease;overflow-x:hidden}.App{max-width:1400px;margin:0 auto;padding:0 calc(var(--spacing-unit) * 4);overflow-x:hidden}h1,h2,h3{font-family:var(--font-secondary);color:var(--primary);line-height:1.2}h1{font-size:4rem}h2{font-size:2.5rem}h3{font-size:1.5rem}p{color:var(--secondary);margin-bottom:calc(var(--spacing-unit) * 2)}a{color:var(--accent);text-decoration:none;transition:color .3s ease}a:hover{color:var(--accent-hover)}button{font-family:var(--font-secondary);cursor:pointer;border:none;border-radius:4px;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);font-size:1rem;transition:background-color .3s ease,transform .2s ease}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.theme-toggle{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-color);background-color:var(--surface);color:var(--secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1000;transition:all .3s ease;box-shadow:0 2px 8px #00000014;padding:0}.theme-toggle:hover{color:var(--primary);border-color:var(--secondary);transform:scale(1.08)}.theme-toggle svg{width:20px;height:20px}@media (max-width: 768px){.App{padding:0 calc(var(--spacing-unit) * 2)}h1{font-size:2rem}h2{font-size:1.6rem}h3{font-size:1.15rem}.theme-toggle{bottom:1.25rem;right:1.25rem;width:44px;height:44px}.theme-toggle svg{width:18px;height:18px}}@media (max-width: 480px){.App{padding:0 calc(var(--spacing-unit) * 1.5)}h1{font-size:1.75rem}h2{font-size:1.4rem}h3{font-size:1.05rem}}@supports (padding: env(safe-area-inset-bottom)){.theme-toggle{bottom:calc(1.25rem + env(safe-area-inset-bottom));right:calc(1.25rem + env(safe-area-inset-right))}}
