.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background-color:var(--bg-primary);border-bottom:1px solid var(--border-subtle);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:rgba(var(--bg-primary-rgb, 250, 249, 247),.85)}[data-theme=dark] .header{background-color:#0f0f0fd9}.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.logo{display:flex;align-items:center;gap:8px;text-decoration:none}.logo-text{font-family:var(--font-serif);font-size:1.25rem;color:var(--text-primary);font-style:italic}.nav{display:flex;gap:32px}.nav-link{font-size:.9375rem;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast);position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background-color:var(--accent-primary);transition:width var(--transition-base)}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-link.active{color:var(--text-primary)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;color:var(--text-secondary);transition:background-color var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background-color:var(--bg-secondary);color:var(--text-primary)}@media (max-width: 640px){.nav{gap:20px}.nav-link{font-size:.875rem}}.layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:var(--header-height)}.footer{padding:32px 0;border-top:1px solid var(--border-subtle);text-align:center}.footer p{color:var(--text-muted);font-size:.875rem}.chatbot{display:flex;flex-direction:column;height:500px;max-height:60vh;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg)}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.message{display:flex;max-width:85%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-content{padding:12px 16px;border-radius:16px;line-height:1.5;font-size:.9375rem}.message.user .message-content{background-color:var(--chat-user-bg);color:var(--chat-user-text);border-bottom-right-radius:4px}.message.assistant .message-content{background-color:var(--chat-bot-bg);color:var(--chat-bot-text);border-bottom-left-radius:4px}.typing{display:flex;gap:4px;padding:16px 20px}.typing span{width:8px;height:8px;background-color:var(--text-muted);border-radius:50%;animation:pulse 1.4s infinite ease-in-out}.typing span:nth-child(1){animation-delay:0ms}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}.quick-prompts{display:flex;flex-wrap:wrap;gap:8px;padding:0 24px 16px}.quick-prompt{padding:8px 16px;font-size:.875rem;color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;transition:all var(--transition-fast)}.quick-prompt:hover{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent-primary)}.chat-input-form{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border-subtle);background-color:var(--bg-secondary)}.chat-input{flex:1;padding:12px 16px;font-size:.9375rem;font-family:inherit;color:var(--text-primary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.chat-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e07a5f26}.chat-input::placeholder{color:var(--text-muted)}.chat-send{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background-color:var(--accent-primary);color:#fff;border-radius:12px;transition:background-color var(--transition-fast),transform var(--transition-fast)}.chat-send:hover:not(:disabled){background-color:var(--accent-secondary);transform:scale(1.05)}.chat-send:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.chatbot{height:400px;border-radius:12px}.chat-messages{padding:16px}.quick-prompts{padding:0 16px 12px}.chat-input-form{padding:12px 16px}}.home{min-height:calc(100vh - var(--header-height));position:relative;overflow:hidden}.home-bg-pattern{position:absolute;top:0;left:0;right:0;height:100%;pointer-events:none;opacity:.4;background:radial-gradient(ellipse 80% 50% at 50% -20%,var(--accent-primary),transparent),radial-gradient(ellipse 60% 40% at 100% 50%,var(--accent-tertiary),transparent),radial-gradient(ellipse 50% 30% at 0% 80%,var(--accent-secondary),transparent)}[data-theme=dark] .home-bg-pattern{opacity:.15}.home-content{position:relative;z-index:1;padding-top:80px;padding-bottom:80px}.hero-section{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;min-height:calc(100vh - var(--header-height) - 160px)}.hero-intro{display:flex;flex-direction:column;gap:24px}.headshot{width:140px;height:140px;border-radius:50%;overflow:hidden;border:3px solid var(--border-color);background-color:var(--bg-secondary)}.headshot img{width:100%;height:100%;object-fit:cover}.headshot-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%)}.hero-title{font-size:clamp(2.5rem,5vw,3.5rem);line-height:1.1}.hero-title .highlight{color:var(--accent-primary);font-style:italic}.hero-subtitle{font-size:1.125rem;color:var(--text-secondary);line-height:1.7;max-width:500px}.hero-tags{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.tag{padding:8px 16px;font-size:.875rem;color:var(--text-secondary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:24px}.chatbot-section{display:flex;flex-direction:column;gap:12px}.chatbot-header{display:flex;align-items:center;gap:8px}.chatbot-status{width:8px;height:8px;background-color:var(--accent-tertiary);border-radius:50%;animation:pulse 2s infinite}.chatbot-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 1024px){.hero-section{grid-template-columns:1fr;gap:60px}.hero-intro{text-align:center;align-items:center}.hero-subtitle{max-width:600px}.hero-tags,.chatbot-header{justify-content:center}}@media (max-width: 640px){.home-content{padding-top:40px;padding-bottom:40px}.headshot{width:120px;height:120px}.hero-section{gap:40px}}.project-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.project-card-link{display:block;text-decoration:none;color:inherit}.project-image{position:relative;aspect-ratio:16 / 10;overflow:hidden;background-color:var(--bg-secondary)}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.project-card:hover .project-image img{transform:scale(1.05)}.project-image.placeholder{display:flex;align-items:center;justify-content:center}.placeholder-pattern{width:100%;height:100%;background:linear-gradient(135deg,var(--accent-primary) 0%,transparent 50%),linear-gradient(225deg,var(--accent-secondary) 0%,transparent 50%),linear-gradient(45deg,var(--accent-tertiary) 0%,transparent 50%);opacity:.3}.project-card-content{padding:24px}.project-title{font-size:1.25rem;margin-bottom:8px;color:var(--text-primary);transition:color var(--transition-fast)}.project-card:hover .project-title{color:var(--accent-primary)}.project-description{color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin-bottom:16px}.project-tech{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tech-tag{padding:4px 12px;font-size:.75rem;font-weight:500;color:var(--text-secondary);background-color:var(--bg-secondary);border-radius:20px}.tech-tag.more{color:var(--accent-primary)}.project-links{display:flex;gap:16px}.project-link-indicator{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-muted)}.project-link-indicator svg{opacity:.7}.projects-page{padding:80px 0}.page-header{text-align:center;margin-bottom:48px}.page-header h1{margin-bottom:16px}.page-description{color:var(--text-secondary);font-size:1.125rem;max-width:600px;margin:0 auto}.filter-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:48px}.filter-btn{padding:8px 20px;font-size:.875rem;color:var(--text-secondary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;transition:all var(--transition-fast)}.filter-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.filter-btn.active{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.projects-grid,.loading-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:32px}.loading-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden}.loading-image{aspect-ratio:16 / 10;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.loading-content{padding:24px;display:flex;flex-direction:column;gap:12px}.loading-line{height:16px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.loading-line.title{height:24px;width:70%}.loading-line.short{width:50%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:80px 0;color:var(--text-muted)}.empty-state p{margin-bottom:16px}@media (max-width: 768px){.projects-page{padding:40px 0}.projects-grid,.loading-grid{grid-template-columns:1fr}}.project-detail-page{padding:60px 0 80px}.back-link{display:inline-flex;align-items:center;gap:4px;color:var(--text-muted);font-size:.875rem;margin-bottom:32px;transition:color var(--transition-fast)}.back-link:hover{color:var(--accent-primary)}.project-header{margin-bottom:48px}.project-header h1{margin-bottom:16px}.project-tagline{font-size:1.25rem;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.project-meta{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px}.tech-stack{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{padding:6px 14px;font-size:.8125rem;color:var(--text-secondary);background-color:var(--bg-secondary);border-radius:20px}.project-actions{display:flex;gap:12px}.action-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;font-size:.9375rem;color:var(--text-primary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;text-decoration:none;transition:all var(--transition-fast)}.action-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.action-btn.primary{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.action-btn.primary:hover{background-color:var(--accent-secondary);border-color:var(--accent-secondary);color:#fff}.project-hero-image{margin-bottom:48px;border-radius:16px;overflow:hidden;border:1px solid var(--border-color)}.project-hero-image img{width:100%;height:auto}.project-content{max-width:720px}.project-content h2{margin-top:48px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.project-content h3{margin-top:32px;margin-bottom:16px}.project-content p{margin-bottom:16px;color:var(--text-secondary);line-height:1.8}.project-content ul,.project-content ol{margin-bottom:16px;padding-left:24px;color:var(--text-secondary)}.project-content li{margin-bottom:8px;line-height:1.7}.project-content code{font-family:SF Mono,Fira Code,monospace;font-size:.875em;padding:2px 6px;background-color:var(--bg-secondary);border-radius:4px}.project-content pre{margin-bottom:20px;padding:20px;background-color:var(--bg-secondary);border-radius:8px;overflow-x:auto}.project-content pre code{padding:0;background:none}.project-content blockquote{margin:24px 0;padding:16px 24px;border-left:3px solid var(--accent-primary);background-color:var(--bg-secondary);border-radius:0 8px 8px 0}.project-content blockquote p{margin-bottom:0;font-style:italic}.loading-state{padding:80px 0;display:flex;flex-direction:column;gap:16px;max-width:400px}@media (max-width: 768px){.project-detail-page{padding:40px 0 60px}.project-meta{flex-direction:column;align-items:flex-start}.project-actions{width:100%}.action-btn{flex:1;justify-content:center}}.blog-page{padding:80px 0}.posts-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.post-card{padding:32px;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;transition:transform var(--transition-base),box-shadow var(--transition-base)}.post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.post-link{display:block;text-decoration:none;color:inherit}.post-date{display:block;font-size:.8125rem;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.03em}.post-title{font-size:1.5rem;margin-bottom:12px;color:var(--text-primary);transition:color var(--transition-fast)}.post-card:hover .post-title{color:var(--accent-primary)}.post-excerpt{color:var(--text-secondary);line-height:1.7;margin-bottom:16px}.post-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.post-tags .tag{padding:4px 12px;font-size:.75rem;color:var(--text-muted);background-color:var(--bg-secondary);border-radius:16px}.read-more{font-size:.875rem;color:var(--accent-primary);font-weight:500}.post-card.loading{pointer-events:none}.post-card.loading .loading-line{height:16px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;margin-bottom:12px}.post-card.loading .loading-line.date{height:12px;width:120px}.post-card.loading .loading-line.title{height:28px;width:80%}.post-card.loading .loading-line.short{width:60%}.empty-state{text-align:center;padding:80px 0;max-width:500px;margin:0 auto}.empty-icon{display:flex;justify-content:center;margin-bottom:24px;color:var(--text-muted);opacity:.5}.empty-state h2{margin-bottom:16px}.empty-state p{color:var(--text-secondary);line-height:1.7}@media (max-width: 768px){.blog-page{padding:40px 0}.post-card{padding:24px}.post-title{font-size:1.25rem}}.blog-post-page{padding:60px 0 80px}.post-article{max-width:720px;margin:0 auto}.post-header{margin-bottom:48px;padding-bottom:32px;border-bottom:1px solid var(--border-subtle)}.post-header .post-date{display:block;font-size:.875rem;color:var(--text-muted);margin-bottom:16px;text-transform:uppercase;letter-spacing:.03em}.post-header h1{font-size:clamp(2rem,4vw,2.75rem);line-height:1.2;margin-bottom:20px}.post-header .post-tags{display:flex;flex-wrap:wrap;gap:8px}.post-header .tag{padding:6px 14px;font-size:.8125rem;color:var(--text-secondary);background-color:var(--bg-secondary);border-radius:20px}.post-content{color:var(--text-secondary);font-size:1.0625rem;line-height:1.8}.post-content h1{margin-top:56px;margin-bottom:24px;font-size:2rem}.post-content h2{margin-top:48px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.post-content h3{margin-top:36px;margin-bottom:16px}.post-content p{margin-bottom:20px}.post-content ul,.post-content ol{margin-bottom:20px;padding-left:28px}.post-content li{margin-bottom:10px}.post-content a{color:var(--accent-primary);text-decoration:underline;text-underline-offset:2px}.post-content a:hover{color:var(--accent-secondary)}.post-content strong{color:var(--text-primary);font-weight:600}.post-content em{font-style:italic}.post-content code{font-family:SF Mono,Fira Code,monospace;font-size:.875em;padding:2px 8px;background-color:var(--bg-secondary);border-radius:4px}.post-content pre{margin:24px 0;padding:24px;background-color:var(--bg-secondary);border-radius:12px;overflow-x:auto}.post-content pre code{padding:0;background:none;font-size:.875rem;line-height:1.6}.post-content blockquote{margin:28px 0;padding:20px 28px;border-left:3px solid var(--accent-primary);background-color:var(--bg-secondary);border-radius:0 12px 12px 0}.post-content blockquote p{margin-bottom:0;font-style:italic;color:var(--text-primary)}.post-content hr{margin:48px 0;border:none;height:1px;background-color:var(--border-color)}.post-content img{margin:32px 0;border-radius:12px;border:1px solid var(--border-color)}.loading-state{padding:80px 0;max-width:400px}.not-found{text-align:center;padding:80px 0}.not-found h2{margin-bottom:16px}@media (max-width: 768px){.blog-post-page{padding:40px 0 60px}.post-content{font-size:1rem}}:root{--font-serif: "Instrument Serif", Georgia, serif;--font-sans: "DM Sans", system-ui, sans-serif;--max-width: 1200px;--header-height: 72px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12)}[data-theme=light]{--bg-primary: #faf9f7;--bg-secondary: #f0eeeb;--bg-tertiary: #e8e6e1;--bg-card: #ffffff;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-muted: #7a7a7a;--accent-primary: #e07a5f;--accent-secondary: #3d405b;--accent-tertiary: #81b29a;--border-color: #e0ded9;--border-subtle: #ebe9e4;--chat-user-bg: #e07a5f;--chat-user-text: #ffffff;--chat-bot-bg: #f0eeeb;--chat-bot-text: #1a1a1a}[data-theme=dark]{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #252525;--bg-card: #1f1f1f;--text-primary: #f5f5f5;--text-secondary: #b0b0b0;--text-muted: #707070;--accent-primary: #e07a5f;--accent-secondary: #8d90b7;--accent-tertiary: #81b29a;--border-color: #2a2a2a;--border-subtle: #222222;--chat-user-bg: #e07a5f;--chat-user-text: #ffffff;--chat-bot-bg: #252525;--chat-bot-text: #f5f5f5}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);transition:background-color var(--transition-base),color var(--transition-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:400;line-height:1.2;color:var(--text-primary)}h1{font-size:clamp(2.5rem,6vw,4rem)}h2{font-size:clamp(1.75rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.5rem)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-secondary)}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;background:none}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn var(--transition-slow) forwards}.animate-slide-up{animation:slideUp var(--transition-slow) forwards}.stagger-children>*{opacity:0;animation:slideUp var(--transition-slow) forwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:.1s}.stagger-children>*:nth-child(3){animation-delay:.2s}.stagger-children>*:nth-child(4){animation-delay:.3s}.stagger-children>*:nth-child(5){animation-delay:.4s}.stagger-children>*:nth-child(6){animation-delay:.5s}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background-color:var(--accent-primary);color:#fff}
