:root{--bg-primary:#faf8f5;--bg-secondary:#ffffff;--bg-tertiary:#f3f0ec;--text-primary:#2d2a32;--text-secondary:#5c5666;--text-muted:#8a8294;--accent:#9b8ec4;--accent-hover:#8578b3;--accent-light:#ede8f5;--border:#e8e3ed;--shadow:rgba(100, 90, 120, 0.08);--shadow-lg:rgba(100, 90, 120, 0.14);--code-bg:#f5f2f8;--tag-bg:#ede8f5;--tag-text:#5c5666;--card-hover:#f9f7fc}[data-theme=dark]{--bg-primary:#1a1720;--bg-secondary:#221f28;--bg-tertiary:#2a2632;--text-primary:#e8e4ee;--text-secondary:#b0a8c0;--text-muted:#7a7290;--accent:#b8a9d8;--accent-hover:#c9bde6;--accent-light:#2e2840;--border:#353040;--shadow:rgba(0, 0, 0, 0.35);--shadow-lg:rgba(0, 0, 0, 0.55);--code-bg:#252130;--tag-bg:#2e2840;--tag-text:#b0a8c0;--card-hover:#262230}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,helvetica neue,Arial,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}.site-header{position:sticky;top:0;z-index:100;background-color:var(--bg-secondary);border-bottom:1px solid var(--border);backdrop-filter:blur(8px);background-color:color-mix(in srgb,var(--bg-secondary) 85%,transparent)}.header-inner{max-width:1100px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.site-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.site-title:hover{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}.nav-links a{color:var(--text-secondary);font-size:.9rem;font-weight:500;position:relative}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background-color:var(--accent);transition:width .2s ease}.nav-links a:hover::after,.nav-links a.active::after{width:100%}.theme-toggle{background:0 0;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease,color .2s ease}.theme-toggle:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.theme-toggle svg{width:20px;height:20px}.theme-toggle .sun-icon{display:none}.theme-toggle .moon-icon{display:block}[data-theme=dark] .theme-toggle .sun-icon{display:block}[data-theme=dark] .theme-toggle .moon-icon{display:none}main{max-width:1100px;margin:0 auto;padding:0 1.5rem}.hero{padding:5rem 0 4rem;text-align:center}.hero h1{font-size:2.5rem;font-weight:800;letter-spacing:-.03em;margin-bottom:1rem;line-height:1.2}.hero .accent{color:var(--accent)}.hero p{font-size:1.1rem;color:var(--text-secondary);max-width:650px;margin:0 auto;line-height:1.7}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:2rem;letter-spacing:-.02em;position:relative;display:inline-block}.section-title::after{content:'';position:absolute;bottom:-8px;left:0;width:40px;height:3px;background-color:var(--accent);border-radius:2px}.section-title svg{width:1.25em;height:1.25em;vertical-align:-.15em;margin-right:.35em;color:var(--accent)}.wave-icon{display:inline-flex;animation:wave 2.5s ease-in-out infinite;transform-origin:70% 70%;width:1.5em;height:1.5em;vertical-align:-.25em;color:var(--accent)}@keyframes wave{0%,60%,100%{transform:rotate(0)}10%,30%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}.skill-icon{display:inline-flex;width:1.1em;height:1.1em;vertical-align:-.15em;margin-right:.4em;color:var(--accent)}.skill-card h3 svg{width:1.25em;height:1.25em}.meta svg,.date svg,.date-location svg{width:.9em;height:.9em;vertical-align:-.1em;margin-right:.25em;color:var(--text-muted);flex-shrink:0}.meta .tags svg{margin-right:.35em;color:var(--accent)}.meta .tags{display:inline-flex;align-items:center;gap:.35rem}h3 a svg,h2 a svg{width:.85em;height:.85em;vertical-align:-.05em;color:var(--text-muted);transition:transform .2s ease,color .2s ease}h3 a:hover svg,h2 a:hover svg{color:var(--accent);transform:translateX(3px)}.cta-button svg{width:1em;height:1em;vertical-align:-.1em;margin-left:.25em}.repo-link svg{width:1.1em;height:1.1em}.experience-card h3 svg,.experience-card .company svg,.experience-card .date-location svg{width:.9em;height:.9em;vertical-align:-.1em;margin-right:.3em;color:var(--text-muted)}.timeline-item .meta svg{width:.85em;height:.85em}.page-header h1 svg{width:1.1em;height:1.1em;vertical-align:-.1em;margin-right:.3em;color:var(--accent)}.skills-section{padding:3rem 0 4rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.skill-card{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.skill-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow);border-color:var(--accent)}.skill-card h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.skill-card ul{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}.skill-card li{font-size:.85rem;color:var(--text-secondary);background-color:var(--tag-bg);padding:.25rem .75rem;border-radius:999px}.projects-section{padding:3rem 0 4rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.project-card{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px var(--shadow-lg)}.project-card-image{width:100%;aspect-ratio:16/9;object-fit:cover;background-color:var(--bg-tertiary)}.project-card-content{padding:1.25rem;flex:1;display:flex;flex-direction:column}.project-card h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.project-card h3 a{color:var(--text-primary)}.project-card h3 a:hover{color:var(--accent)}.project-card p{font-size:.9rem;color:var(--text-secondary);flex:1}.project-card .date{font-size:.8rem;color:var(--text-muted);margin-top:.75rem}.projects-list-rows{display:flex;flex-direction:column;gap:0}.project-row{display:flex;gap:1.5rem;padding:1.25rem 0;border-bottom:1px solid var(--border);color:inherit;text-decoration:none;transition:background-color .2s ease;border-radius:8px;padding-left:.75rem;padding-right:.75rem;margin-left:-.75rem;margin-right:-.75rem}.project-row:hover{background-color:var(--card-hover)}.project-row:last-child{border-bottom:none}.row-thumb{width:180px;height:120px;object-fit:cover;border-radius:8px;flex-shrink:0;background-color:var(--bg-tertiary)}.row-content{flex:1;display:flex;flex-direction:column;justify-content:center}.row-content h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem;display:flex;align-items:center;gap:.3rem}.row-content h3 svg{width:.85em;height:.85em;color:var(--text-muted);transition:transform .2s ease,color .2s ease}.project-row:hover .row-content h3 svg{color:var(--accent);transform:translateX(3px)}.row-content p{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.5rem}.row-content .date{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.row-content .date svg{width:.85em;height:.85em}.timeline-section{padding:3rem 0 4rem}.timeline{position:relative;padding-left:2rem}.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background-color:var(--border)}.timeline-item{position:relative;padding-bottom:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-item::before{content:'';position:absolute;left:-2rem;top:.35rem;width:12px;height:12px;border-radius:50%;background-color:var(--accent);border:3px solid var(--bg-primary);transform:translateX(-5px)}.timeline-item h3{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.timeline-item .subtitle{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.timeline-item .meta{font-size:.85rem;color:var(--text-muted);display:flex;gap:1rem;flex-wrap:wrap}.timeline-item .meta span{display:flex;align-items:center;gap:.35rem}.experience-card{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;transition:border-color .2s ease}.experience-card:hover{border-color:var(--accent)}.experience-card h3{font-size:1.15rem;font-weight:600;margin-bottom:.25rem}.experience-card .company{font-size:.95rem;color:var(--accent);margin-bottom:.25rem}.experience-card .date-location{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.experience-card .content{font-size:.95rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1rem}.experience-card .actions{list-style:none}.experience-card .actions li{font-size:.9rem;color:var(--text-secondary);padding:.35rem 0;padding-left:1.25rem;position:relative}.experience-card .actions li::before{content:'';position:absolute;left:0;top:.75rem;width:6px;height:6px;background-color:var(--accent);border-radius:50%}.blog-list{padding:3rem 0 4rem}.blog-post-item{padding:1.5rem 0;border-bottom:1px solid var(--border)}.blog-post-item:last-child{border-bottom:none}.blog-post-item h2{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.blog-post-item h2 a{color:var(--text-primary)}.blog-post-item h2 a:hover{color:var(--accent)}.blog-post-item .meta{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.blog-post-item .summary{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.blog-single{padding:3rem 0 4rem;max-width:720px;margin:0 auto}.blog-single h1{font-size:2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.75rem;line-height:1.2}.blog-single .meta{font-size:.9rem;color:var(--text-muted);margin-bottom:2rem;display:flex;gap:1rem;align-items:center}.blog-single .content{line-height:1.8}.blog-single .content h2{font-size:1.5rem;font-weight:700;margin:2rem 0 1rem;letter-spacing:-.02em}.blog-single .content h3{font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem}.blog-single .content p{margin-bottom:1.25rem;color:var(--text-secondary)}.blog-single .content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.blog-single .content ul,.blog-single .content ol{margin-bottom:1.25rem;padding-left:1.5rem;color:var(--text-secondary)}.blog-single .content li{margin-bottom:.5rem}.blog-single .content img{max-width:100%;border-radius:8px;margin:1.5rem 0}.blog-single .content code{background-color:var(--code-bg);padding:.2rem .4rem;border-radius:4px;font-size:.9em;font-family:sf mono,fira code,monospace}.blog-single .content pre{background-color:var(--code-bg);padding:1rem;border-radius:8px;overflow-x:auto;margin-bottom:1.25rem}.blog-single .content pre code{background:0 0;padding:0}.blog-single .content blockquote{border-left:3px solid var(--accent);padding-left:1rem;margin:1.25rem 0;color:var(--text-muted);font-style:italic}.tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tag{font-size:.8rem;color:var(--tag-text);background-color:var(--tag-bg);padding:.25rem .75rem;border-radius:999px;transition:background-color .2s ease}.tag:hover{background-color:var(--accent-light);color:var(--accent)}.project-single{padding:3rem 0 4rem;max-width:800px;margin:0 auto}.project-single h1{font-size:2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem;line-height:1.2}.project-single .meta{font-size:.9rem;color:var(--text-muted);margin-bottom:2rem}.project-single .hero-image{width:100%;border-radius:12px;margin-bottom:2rem;background-color:var(--bg-tertiary)}.project-single .content{line-height:1.8}.project-single .content h2{font-size:1.5rem;font-weight:700;margin:2rem 0 1rem;letter-spacing:-.02em}.project-single .content h3{font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem}.project-single .content p{margin-bottom:1.25rem;color:var(--text-secondary)}.project-single .content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.project-single .content ul,.project-single .content ol{margin-bottom:1.25rem;padding-left:1.5rem;color:var(--text-secondary)}.project-single .content li{margin-bottom:.5rem}.project-single .content img{max-width:100%;border-radius:8px;margin:1.5rem 0}.project-single .repo-link{display:inline-flex;align-items:center;gap:.5rem;background-color:var(--accent);color:#fff;padding:.75rem 1.25rem;border-radius:8px;font-weight:500;margin-bottom:2rem;transition:background-color .2s ease}.project-single .repo-link:hover{background-color:var(--accent-hover);color:#fff}.site-footer{border-top:1px solid var(--border);padding:2rem 0;margin-top:4rem}.footer-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center}.footer-inner p{font-size:.85rem;color:var(--text-muted)}.social-links{display:flex;gap:1rem}.social-links a{color:var(--text-muted);display:flex;align-items:center;transition:color .2s ease}.social-links a:hover{color:var(--accent)}.social-links svg{width:20px;height:20px}.page-header{padding:3rem 0 2rem}.page-header h1{font-size:2rem;font-weight:800;letter-spacing:-.03em}.cta-section{padding:3rem 0 4rem;text-align:center}.cta-section p{color:var(--text-secondary);margin-bottom:1.5rem}.cta-button{display:inline-block;background-color:var(--accent);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;transition:background-color .2s ease}.cta-button:hover{background-color:var(--accent-hover);color:#fff}.mobile-menu-toggle{display:none;background:0 0;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary)}.mobile-menu-toggle svg{width:24px;height:24px}@media(max-width:768px){.mobile-menu-toggle{display:block}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background-color:var(--bg-secondary);border-bottom:1px solid var(--border);flex-direction:column;padding:1rem 1.5rem;gap:1rem}.nav-links.open{display:flex}.hero h1{font-size:2rem}.skills-grid{grid-template-columns:1fr}.projects-grid{grid-template-columns:1fr}.project-row{flex-direction:column}.row-thumb{width:100%;height:180px}.footer-inner{flex-direction:column;gap:1rem;text-align:center}}