:root{--evergreen: #132a13;--hunter-green: #31572c;--lime-cream: #ecf39e;--fern: #4f772d;--palm-leaf: #90a955;--body-text: #c8d8b0;--text-muted: #8aab6e;--text-subtle: #6a8f52;--border-subtle: rgba(79, 119, 45, .25);--border-medium: rgba(79, 119, 45, .5);--card-bg: rgba(49, 87, 44, .18);--card-bg-hover: rgba(49, 87, 44, .38);--glow-palm: 0 0 24px rgba(144, 169, 85, .35);--glow-lime: 0 0 24px rgba(236, 243, 158, .2);--transition-fast: .15s ease;--transition-base: .26s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--max-width: 1200px;--nav-height: 72px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--evergreen);color:var(--body-text);line-height:1.7;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea,select{font-family:inherit}h1,h2,h3,h4{color:var(--lime-cream);line-height:1.2;font-weight:700;letter-spacing:-.02em}h1{font-size:clamp(2rem,5vw,3.75rem)}h2{font-size:clamp(1.5rem,3vw,2.25rem)}h3{font-size:clamp(1.1rem,2vw,1.45rem)}h4{font-size:1.1rem}p{color:var(--body-text);line-height:1.75}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--evergreen)}::-webkit-scrollbar-thumb{background:var(--hunter-green);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--fern)}::selection{background:#90a9554d;color:var(--lime-cream)}:focus-visible{outline:2px solid var(--palm-leaf);outline-offset:3px;border-radius:4px}.navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-height);z-index:1000;background:#132a13e0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border-subtle)}.nav-container{max-width:var(--max-width);margin:0 auto;padding:0 2rem;height:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:2px;font-size:1.05rem;font-weight:700;letter-spacing:-.01em;transition:opacity var(--transition-fast)}.nav-logo:hover{opacity:.78}.logo-bracket{color:var(--palm-leaf);font-weight:400}.logo-name{color:var(--lime-cream)}.nav-menu{display:flex;align-items:center;gap:2.5rem}.nav-link{color:var(--body-text);font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:color var(--transition-fast);position:relative;padding-bottom:2px}.nav-link:after{content:"";position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--lime-cream);transition:width var(--transition-base)}.nav-link:hover,.nav-link.active{color:var(--lime-cream)}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-toggle{display:none;flex-direction:column;gap:5px;padding:4px}.nav-toggle span{display:block;width:22px;height:2px;background:var(--body-text);transition:all var(--transition-base);transform-origin:center}.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}main{padding-top:var(--nav-height);min-height:100vh}.container{max-width:var(--max-width);margin:0 auto;padding:0 2rem}.section-header{margin-bottom:2.75rem}.section-label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--palm-leaf);margin-bottom:.6rem}.section-divider{width:44px;height:2px;background:linear-gradient(90deg,var(--fern),transparent);margin-top:.85rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:700;letter-spacing:.04em;transition:all var(--transition-base);cursor:pointer}.btn-primary{background:var(--lime-cream);color:var(--evergreen);border:2px solid var(--lime-cream)}.btn-primary:hover{background:transparent;color:var(--lime-cream);box-shadow:var(--glow-lime)}.btn-outline{background:transparent;color:var(--lime-cream);border:1px solid var(--border-medium)}.btn-outline:hover{border-color:var(--lime-cream);background:#ecf39e0f}.tag{display:inline-block;padding:.22rem .7rem;border-radius:100px;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.tag-tutorials{background:#90a95524;color:var(--palm-leaf);border:1px solid rgba(144,169,85,.32)}.tag-devlog{background:#4f772d24;color:#7daa4f;border:1px solid rgba(79,119,45,.3)}.tag-opinion{background:#ecf39e14;color:#c8d870;border:1px solid rgba(236,243,158,.2)}.status-badge{display:inline-flex;align-items:center;gap:.6rem;padding:.5rem 1.25rem;background:#90a95517;border:1px solid rgba(144,169,85,.38);border-radius:100px;font-size:.8rem;font-weight:600;letter-spacing:.04em;color:var(--palm-leaf);box-shadow:0 0 18px #90a9552e,inset 0 0 14px #90a9550f}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--palm-leaf);box-shadow:0 0 8px var(--palm-leaf);animation:pulse-dot 2.2s ease-in-out infinite}.footer{border-top:1px solid var(--border-subtle);padding:2.25rem 0;margin-top:6rem}.footer-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.footer-text{font-size:.83rem;color:var(--text-muted)}.footer-links{display:flex;gap:2rem}.footer-links a{font-size:.8rem;color:var(--text-muted);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--lime-cream)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.82)}}@keyframes spin{to{transform:rotate(360deg)}}.page-hero{padding:5rem 0 3.5rem;border-bottom:1px solid var(--border-subtle)}.page-hero-label{display:block;margin-bottom:1rem;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--palm-leaf)}.page-hero-title{color:var(--lime-cream);margin-bottom:1rem}.page-hero-desc{max-width:540px;color:var(--text-muted);font-size:1rem}.featured-section{padding:4rem 0 1rem}.featured-post{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;min-height:360px;transition:all var(--transition-base);position:relative}.featured-post:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(144,169,85,.06) 0%,transparent 55%);pointer-events:none}.featured-post:hover{border-color:var(--border-medium);box-shadow:var(--glow-palm);transform:translateY(-2px)}.featured-post-media{background:#31572c61;position:relative;overflow:hidden;min-height:260px}.featured-post-art{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 35% 50%,rgba(144,169,85,.22) 0%,transparent 60%),radial-gradient(ellipse at 78% 18%,rgba(79,119,45,.28) 0%,transparent 52%),linear-gradient(145deg,#31572c8c,#132a13e0);display:flex;align-items:center;justify-content:center}.featured-art-icon{font-size:5.5rem;opacity:.35}.featured-post-label{position:absolute;top:1.25rem;left:1.25rem;font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--evergreen);background:var(--lime-cream);padding:.3rem .85rem;border-radius:100px}.featured-post-content{padding:2.75rem;display:flex;flex-direction:column;justify-content:center;gap:1.1rem}.featured-post-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.featured-post-date{font-size:.8rem;color:var(--text-muted)}.featured-post-read-time{font-size:.8rem;color:var(--text-subtle)}.featured-post-title{font-size:clamp(1.35rem,2.4vw,1.9rem);color:var(--lime-cream);line-height:1.25}.featured-post-excerpt{font-size:.93rem;color:var(--body-text);line-height:1.7}.featured-post-link{display:inline-flex;align-items:center;gap:.45rem;color:var(--lime-cream);font-weight:700;font-size:.88rem;margin-top:.25rem;transition:gap var(--transition-fast)}.featured-post-link:hover{gap:.7rem}.search-filter-bar{padding:2rem 0;border-bottom:1px solid var(--border-subtle);margin-bottom:3rem}.search-filter-inner{display:flex;gap:1.25rem;align-items:center;flex-wrap:wrap}.search-wrapper{position:relative;flex:1;min-width:240px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-subtle);pointer-events:none}.search-input{width:100%;padding:.78rem 1rem .78rem 2.8rem;background:#31572c2e;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--body-text);font-size:.9rem;transition:all var(--transition-base)}.search-input::placeholder{color:var(--text-subtle)}.search-input:focus{outline:none;border-color:var(--palm-leaf);background:#31572c47;box-shadow:0 0 0 3px #90a95524}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.55rem 1.2rem;border-radius:100px;font-size:.78rem;font-weight:600;letter-spacing:.04em;border:1px solid var(--border-subtle);color:var(--text-muted);background:transparent;transition:all var(--transition-fast);cursor:pointer}.filter-btn:hover{border-color:var(--fern);color:var(--palm-leaf)}.filter-btn.active{background:#4f772d2e;border-color:var(--fern);color:var(--lime-cream)}.blog-grid-section{padding-bottom:4rem}.blog-grid-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.blog-grid-title{font-size:1.2rem;color:var(--lime-cream)}.blog-count{font-size:.8rem;color:var(--text-muted)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem}.blog-card{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.75rem;display:flex;flex-direction:column;gap:1rem;transition:all var(--transition-base);position:relative;overflow:hidden}.blog-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--fern),transparent);opacity:0;transition:opacity var(--transition-base)}.blog-card:hover{border-color:var(--border-medium);background:var(--card-bg-hover);transform:translateY(-3px);box-shadow:0 10px 36px #00000047,var(--glow-palm)}.blog-card:hover:before{opacity:1}.card-header{display:flex;align-items:center;justify-content:space-between}.card-read-time{font-size:.76rem;color:var(--text-subtle)}.card-title{font-size:1.05rem;line-height:1.35}.card-title a{color:var(--lime-cream);transition:color var(--transition-fast)}.card-title a:hover{color:#fff}.card-excerpt{font-size:.87rem;color:var(--text-muted);line-height:1.65;flex:1}.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.card-date{font-size:.76rem;color:var(--text-subtle)}.card-link{font-size:.8rem;font-weight:700;color:var(--lime-cream);display:inline-flex;align-items:center;gap:.35rem;transition:gap var(--transition-fast)}.card-link:hover{gap:.6rem}.empty-state{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state-icon{font-size:2.75rem;margin-bottom:1rem;opacity:.4}.about-hero{padding:5rem 0}.about-hero-grid{display:grid;grid-template-columns:5fr 7fr;gap:5rem;align-items:center}.portrait-side{position:relative}.portrait-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/4;max-width:360px;background:#31572c4d;border:1px solid var(--border-subtle)}.portrait-photo{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.portrait-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 40% 30%,rgba(144,169,85,.24) 0%,transparent 55%),radial-gradient(ellipse at 72% 78%,rgba(79,119,45,.3) 0%,transparent 50%),linear-gradient(160deg,#31572c99,#132a13f0)}.portrait-initials{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.initials-text{font-size:5.5rem;font-weight:800;color:var(--lime-cream);opacity:.12;letter-spacing:-.05em}.initials-label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--palm-leaf);opacity:.65}.portrait-corner-bl{position:absolute;bottom:-1px;right:-1px;width:56px;height:56px;border-right:2px solid var(--palm-leaf);border-bottom:2px solid var(--palm-leaf);border-radius:0 0 var(--radius-lg) 0;opacity:.5}.portrait-corner-tl{position:absolute;top:-1px;left:-1px;width:38px;height:38px;border-left:2px solid var(--fern);border-top:2px solid var(--fern);border-radius:var(--radius-lg) 0 0 0;opacity:.5}.portrait-deco{position:absolute;bottom:-18px;right:-18px;width:110px;height:110px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);transform:rotate(13deg);pointer-events:none}.portrait-deco-2{position:absolute;top:-14px;left:-14px;width:72px;height:72px;border:1px solid rgba(79,119,45,.2);border-radius:var(--radius-sm);transform:rotate(-9deg);pointer-events:none}.bio-side{display:flex;flex-direction:column;gap:2rem}.bio-greeting{font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--palm-leaf)}.bio-name{font-size:clamp(2.4rem,4vw,3.4rem);color:var(--lime-cream);margin-bottom:.2rem}.bio-role{font-size:1.05rem;color:var(--palm-leaf);font-weight:400}.bio-description p+p{margin-top:1rem}.bio-actions{display:flex;gap:1rem;flex-wrap:wrap}.timeline-section{padding:4rem 0;border-top:1px solid var(--border-subtle)}.timeline{position:relative;padding-left:2.5rem;margin-top:1rem}.timeline:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:1px;background:linear-gradient(180deg,var(--fern) 0%,rgba(79,119,45,.1) 100%)}.timeline-item{position:relative;margin-bottom:2.75rem;opacity:0;animation:fadeInUp .5s ease forwards}.timeline-item:nth-child(1){animation-delay:.08s}.timeline-item:nth-child(2){animation-delay:.2s}.timeline-item:nth-child(3){animation-delay:.33s}.timeline-item:nth-child(4){animation-delay:.46s}.timeline-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-2.5rem;top:7px;width:10px;height:10px;border-radius:50%;background:var(--palm-leaf);border:2px solid var(--evergreen);box-shadow:0 0 8px #90a9558c;transform:translate(-4.5px)}.timeline-period{font-size:.75rem;font-weight:700;letter-spacing:.08em;color:var(--palm-leaf);text-transform:uppercase;margin-bottom:.35rem}.timeline-role{font-size:1.12rem;color:var(--lime-cream);margin-bottom:.2rem}.timeline-company{font-size:.88rem;color:var(--fern);font-weight:500;margin-bottom:.65rem}.timeline-desc{font-size:.88rem;color:var(--text-muted);line-height:1.7;max-width:580px}.tech-section{padding:4rem 0;border-top:1px solid var(--border-subtle)}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(125px,1fr));gap:1rem;margin-top:1.5rem}.tech-card{background:#31572c2e;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.7rem;text-align:center;transition:all var(--transition-base);cursor:default}.tech-card:hover{background:#31572c61;border-color:var(--palm-leaf);transform:translateY(-3px);box-shadow:0 6px 24px #00000038,0 0 14px #90a95524}.tech-emoji{font-size:1.7rem;line-height:1}.tech-name{font-size:.78rem;font-weight:600;color:var(--body-text);letter-spacing:.02em}.contact-hero{padding:5rem 0 3.5rem;text-align:center;border-bottom:1px solid var(--border-subtle)}.contact-hero .status-badge{margin-bottom:2rem}.contact-hero-title{color:var(--lime-cream);margin-bottom:1rem}.contact-hero-desc{max-width:500px;margin:0 auto;color:var(--text-muted);font-size:1rem}.contact-layout{padding:4rem 0 5rem;display:grid;grid-template-columns:5fr 7fr;gap:5rem;align-items:start}.contact-info{display:flex;flex-direction:column;gap:2.5rem}.contact-info-title{font-size:1.4rem;color:var(--lime-cream);margin-bottom:.4rem}.contact-info-desc{font-size:.88rem;color:var(--text-muted);line-height:1.7}.contact-details{display:flex;flex-direction:column;gap:1rem}.contact-detail-item{display:flex;align-items:center;gap:1rem}.contact-detail-icon{width:40px;height:40px;flex-shrink:0;background:#31572c47;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem}.contact-detail-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle)}.contact-detail-text{font-size:.88rem;color:var(--body-text)}.social-links-section{display:flex;flex-direction:column;gap:.9rem}.social-links-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-subtle)}.social-links{display:flex;gap:.7rem;flex-wrap:wrap}.social-link{display:flex;align-items:center;gap:.55rem;padding:.58rem 1rem;background:#31572c33;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--lime-cream);font-size:.83rem;font-weight:500;transition:all var(--transition-base)}.social-link:hover{background:#31572c66;border-color:var(--lime-cream);transform:translateY(-2px);box-shadow:0 4px 16px #0003}.social-link svg{width:15px;height:15px;fill:currentColor;flex-shrink:0}.contact-form-wrapper{background:#31572c1a;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:2.5rem}.form-heading{color:var(--lime-cream);font-size:1.18rem;font-weight:600;margin-bottom:1.75rem}.contact-form{display:flex;flex-direction:column;gap:1.2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-label{font-size:.8rem;font-weight:600;color:var(--body-text);letter-spacing:.02em}.form-label .required{color:var(--palm-leaf);margin-left:2px}.form-input,.form-textarea,.form-select{width:100%;padding:.82rem 1rem;background:#132a138c;border:1px solid rgba(49,87,44,.55);border-radius:var(--radius-sm);color:var(--body-text);font-size:.9rem;transition:all var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-subtle)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--palm-leaf);background:#132a13bf;box-shadow:0 0 0 3px #90a95524,0 0 18px #90a95514}.form-input.error,.form-textarea.error,.form-select.error{border-color:#d9534f;box-shadow:0 0 0 3px #d9534f1a}.form-error{font-size:.74rem;color:#e07a7a;display:none}.form-error.visible{display:block}.form-textarea{resize:vertical;min-height:140px;line-height:1.65}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238aab6e' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}.form-select option{background:var(--evergreen);color:var(--body-text)}.btn-submit{width:100%;padding:1rem;background:var(--lime-cream);color:var(--evergreen);border:2px solid var(--lime-cream);border-radius:var(--radius-sm);font-size:.93rem;font-weight:800;letter-spacing:.06em;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.55rem;margin-top:.25rem}.btn-submit:hover:not(:disabled){background:transparent;color:var(--lime-cream);box-shadow:var(--glow-lime)}.btn-submit:disabled{opacity:.55;cursor:not-allowed}.btn-submit .spin{animation:spin .9s linear infinite}.form-success{display:none;text-align:center;padding:3.5rem 2rem;flex-direction:column;align-items:center;gap:1rem}.form-success.visible{display:flex}.success-icon{font-size:3rem}.success-title{font-size:1.45rem;color:var(--lime-cream)}.success-desc{color:var(--text-muted);font-size:.9rem}@media (max-width: 960px){.about-hero-grid{grid-template-columns:1fr;gap:3rem}.portrait-frame{max-width:280px;aspect-ratio:1}.contact-layout{grid-template-columns:1fr;gap:3rem}.featured-post{grid-template-columns:1fr}.featured-post-media{min-height:200px}}@media (max-width: 768px){:root{--nav-height: 64px}.nav-menu{display:none;position:fixed;top:var(--nav-height);left:0;right:0;flex-direction:column;background:#132a13f7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:2rem;gap:1.5rem;border-bottom:1px solid var(--border-subtle)}.nav-menu.open,.nav-toggle{display:flex}.nav-link{font-size:1rem}.form-row{grid-template-columns:1fr}.container{padding:0 1.25rem}.footer-inner{flex-direction:column;text-align:center}.timeline{padding-left:2rem}.contact-form-wrapper{padding:1.75rem}}@media (max-width: 480px){.page-hero{padding:3rem 0 2rem}.search-filter-inner{flex-direction:column;align-items:stretch}.search-wrapper{min-width:unset}.blog-grid{grid-template-columns:1fr}.tech-grid{grid-template-columns:repeat(3,1fr)}.bio-actions{flex-direction:column}.featured-post-content{padding:1.75rem}}.post-page{padding-bottom:6rem}.post-header{padding:4rem 0 3rem;border-bottom:1px solid var(--border-subtle);margin-bottom:3.5rem}.back-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2rem;transition:color var(--transition-fast)}.back-link:hover{color:var(--lime-cream)}.post-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1.25rem}.post-date{font-size:.8rem;color:var(--text-muted)}.post-read-time{font-size:.8rem;color:var(--text-subtle)}.post-title{font-size:clamp(1.75rem,3.5vw,2.75rem);color:var(--lime-cream);line-height:1.2;margin-bottom:1rem}.post-subtitle{font-size:1.05rem;color:var(--text-muted);line-height:1.7;max-width:640px}.prose{max-width:720px;font-size:1.05rem;line-height:1.8;color:var(--body-text)}.prose h2{color:var(--lime-cream);font-size:clamp(1.3rem,2.5vw,1.75rem);margin:2.5rem 0 1rem;line-height:1.25}.prose h3{color:var(--lime-cream);font-size:1.25rem;margin:2rem 0 .75rem}.prose p{margin-bottom:1.4rem}.prose a{color:var(--lime-cream);text-decoration:underline;text-decoration-color:#90a95566;transition:text-decoration-color var(--transition-fast)}.prose a:hover{text-decoration-color:var(--lime-cream)}.prose ul{list-style:disc;margin:0 0 1.4rem 1.5rem;display:flex;flex-direction:column;gap:.4rem}.prose ol{list-style:decimal;margin:0 0 1.4rem 1.5rem;display:flex;flex-direction:column;gap:.4rem}.prose li{color:var(--body-text)}.prose strong{color:var(--lime-cream);font-weight:700}.prose em{font-style:italic}.prose hr{border:none;border-top:1px solid var(--border-subtle);margin:2.5rem 0}.prose blockquote{border-left:3px solid var(--fern);padding:.75rem 1.25rem;margin:1.5rem 0;background:#31572c26;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.prose blockquote p{margin:0;color:var(--text-muted);font-style:italic}.prose code{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.88em;background:#31572c59;border:1px solid var(--border-subtle);border-radius:4px;padding:.15em .4em;color:var(--lime-cream)}.prose pre{background:#132a13b3;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.5rem;overflow-x:auto;margin:1.5rem 0}.prose pre code{background:none;border:none;padding:0;font-size:.9rem;line-height:1.6;color:var(--body-text)}.post-tech-stack{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.5rem}.tech-pill{display:inline-block;font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;font-weight:500;background:#31572c59;border:1px solid rgba(144,169,85,.25);color:var(--palm-leaf);border-radius:4px;padding:.2em .55em;letter-spacing:.02em}.tech-pill--sm{font-size:.68rem;padding:.15em .45em}.card-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
