:root{--color-bg:#ffffff;--color-bg-secondary:#f5f5f5;--color-text:#171717;--color-text-secondary:#525252;--color-text-muted:#737373;--color-accent:#3d9970;--color-accent-hover:#2d7a56;--color-accent-light:#4ca97f;--color-border:#e5e5e5;--color-dark-bg:#111111;--color-dark-bg-secondary:#1a1a1a;--color-dark-text:#fafafa;--color-dark-text-secondary:#a3a3a3;--color-dark-text-muted:#737373;--color-dark-accent:#4ca97f;--color-dark-accent-hover:#6bbf96;--color-dark-accent-light:#5cb88a;--color-dark-border:#262626}*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,sans-serif;font-size:16px;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);transition:background-color .2s ease,color .2s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-accent)}ul{padding-left:1.5rem;margin:0}li{margin:.25rem 0}p{margin:0 0 1rem;line-height:1.7}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;margin:0 0 1rem}h1{font-size:2.5rem;letter-spacing:-.02em}h2{font-size:1.5rem;font-weight:600;margin-top:2.5rem}h3{font-size:1.125rem;font-weight:600}.main{position:relative;margin:0 auto;padding:2rem 1.5rem 4rem;max-width:42rem;min-height:100vh}@media(min-width:640px){.main{padding:3rem 2rem 5rem}}.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4rem}.header-nav{flex:1}.header-nav-list{margin:0;padding:0;display:flex;align-items:center;gap:1.5rem;list-style:none}.header-nav-list-item a{font-size:.9rem;color:var(--color-text-secondary);transition:color .15s ease}.header-nav-list-item a:hover,.header-nav-list-item a.active{color:var(--color-text)}#header-theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient( 180deg,var(--color-bg-secondary) 0%,#ececec 100% );border:1px solid var(--color-border);border-radius:8px;cursor:pointer;color:var(--color-text-secondary);box-shadow:0 1px 3px rgba(0,0,0,6%),0 1px 2px rgba(0,0,0,4%);transition:all .15s ease}#header-theme-toggle:hover{color:var(--color-text);background:linear-gradient(180deg,#ececec 0%,#e0e0e0 100%);box-shadow:0 2px 4px rgba(0,0,0,8%),0 1px 2px rgba(0,0,0,4%)}#header-theme-toggle svg{width:18px;height:18px;fill:currentColor}.theme-icon-sun,.theme-icon-moon{display:none}.theme-icon-moon{display:block}.hero{display:flex;flex-direction:column-reverse;gap:2rem;margin-bottom:3rem}@media(min-width:640px){.hero{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:3rem}}.hero-content{flex:1}.hero-title{font-size:2.5rem;font-weight:700;margin:0 0 .25rem;letter-spacing:-.02em}@media(min-width:640px){.hero-title{font-size:3rem}}.hero-subtitle{font-size:.95rem;color:var(--color-text-secondary);margin:0 0 1rem}.hero-subtitle strong{color:var(--color-text);font-weight:600}.content{font-size:.95rem;line-height:1.7;color:var(--color-text-secondary)}.content a{color:var(--color-accent)}.content a:hover{color:var(--color-accent-hover)}.content ul{margin:1rem 0}.content li{margin-top:0;margin-bottom:.1rem}.content-img-wrapper{position:relative;display:block;max-width:90%;margin:0 auto}.content-img-wrapper img{display:block;width:100%;height:auto;cursor:zoom-in}.content-img-zoom{position:absolute;top:8px;right:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);border-radius:6px;cursor:pointer;opacity:0;transition:opacity .15s ease}.content-img-wrapper:hover .content-img-zoom{opacity:1}.content-img-zoom svg{width:16px;height:16px;fill:#fff}.img-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.img-modal.active{opacity:1;visibility:visible}.img-modal-close{position:absolute;top:20px;right:20px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border:none;border-radius:8px;cursor:pointer;transition:background .15s ease}.img-modal-close:hover{background:rgba(255,255,255,.2)}.img-modal-close svg{width:20px;height:20px;stroke:#fff;stroke-width:2}.img-modal img{max-width:90%;max-height:90%;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.3)}.content blockquote{margin:1.5rem 0;padding:1rem 1.25rem;border-left:3px solid var(--color-accent);background-color:var(--color-bg-secondary);border-radius:0 8px 8px 0;color:var(--color-text-secondary);font-style:italic;box-shadow:0 1px 3px rgba(0,0,0,4%)}.content blockquote p{margin:0}.content blockquote p+p{margin-top:.75rem}.download-cv-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient( 180deg,var(--color-accent-light) 0%,var(--color-accent) 100% );color:#fff!important;font-size:.875rem;font-weight:500;border-radius:8px;text-decoration:none;margin:1.5rem 0 2.5rem;box-shadow:0 2px 4px rgba(61,153,112,.2),0 1px 2px rgba(61,153,112,.1);transition:all .15s ease}.download-cv-btn:hover{background:linear-gradient( 180deg,var(--color-accent) 0%,var(--color-accent-hover) 100% );transform:translateY(-1px);box-shadow:0 4px 8px rgba(61,153,112,.25),0 2px 4px rgba(61,153,112,.15)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-title{font-size:1.25rem;font-weight:600;margin:0}.section-link{font-size:.875rem;color:var(--color-text-muted);display:inline-flex;align-items:center;gap:.25rem}.section-link:hover{color:var(--color-text)}.section-link::after{content:"→";font-size:.9em}.post-list{margin:1.5rem 0}.post-item{display:flex;align-items:baseline;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.post-item:last-child{border-bottom:none}.post-date{font-size:.8rem;color:var(--color-text-muted);min-width:90px;font-variant-numeric:tabular-nums}.post-link{margin:0;flex:1}.post-link a{font-weight:500;color:var(--color-text)}.post-link a:hover{color:var(--color-accent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}@media(max-width:640px){.projects-grid{grid-template-columns:1fr}}.project-card{display:block;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);padding:1rem;border-radius:12px;text-decoration:none;color:inherit;box-shadow:0 1px 3px rgba(0,0,0,4%),0 1px 2px rgba(0,0,0,2%);transition:all .2s ease}.project-card:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,8%),0 2px 4px rgba(0,0,0,4%)}.project-card img{width:100%;height:auto;border-radius:8px;margin-bottom:.75rem}.project-card h3{margin:.5rem 0 0;font-size:1rem;font-weight:600}.project-badges{display:flex;gap:.5rem;margin:.5rem 0 0}.project-badge{background:linear-gradient( 180deg,var(--color-accent-light) 0%,var(--color-accent) 100% );color:#fff;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600}.footer{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--color-border)}.footer p{font-size:.875rem;color:var(--color-text-muted);margin:0}code{font-family:jetbrains mono,ui-monospace,monospace;font-size:.875em;background-color:var(--color-bg-secondary);padding:.2em .4em;border-radius:4px}pre{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;overflow-x:auto}pre code{background:0 0;padding:0}.highlight code{display:block;border-radius:8px;padding:1.25rem;font-size:.875rem;font-family:jetbrains mono,ui-monospace,monospace;line-height:1.6}.page-header{margin-bottom:2rem}.page-title{font-size:2rem;font-weight:700;margin:0 0 .5rem}.page-date{font-size:.875rem;color:var(--color-text-muted)}.terms{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem}.terms a{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);padding:.375rem .75rem;border-radius:6px;font-size:.8rem;color:var(--color-text-secondary)}.terms a:hover{border-color:var(--color-accent);color:var(--color-accent)}body.dark{color:var(--color-dark-text);background-color:var(--color-dark-bg)}.dark a:hover{color:var(--color-dark-accent)}.dark .header-nav-list-item a{color:var(--color-dark-text-secondary)}.dark .header-nav-list-item a:hover,.dark .header-nav-list-item a.active{color:var(--color-dark-text)}.dark #header-theme-toggle{background:linear-gradient( 180deg,#222222 0%,var(--color-dark-bg-secondary) 100% );border-color:var(--color-dark-border);color:var(--color-dark-text-secondary);box-shadow:0 1px 3px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15)}.dark #header-theme-toggle:hover{color:var(--color-dark-text);background:linear-gradient(180deg,#2a2a2a 0%,#222222 100%);box-shadow:0 2px 4px rgba(0,0,0,.25),0 1px 2px rgba(0,0,0,.15)}.dark .theme-icon-moon{display:none}.dark .theme-icon-sun{display:block}.dark .hero-subtitle{color:var(--color-dark-text-secondary)}.dark .hero-subtitle strong{color:var(--color-dark-text)}.dark .content{color:var(--color-dark-text-secondary)}.dark .content a{color:var(--color-dark-accent)}.dark .content a:hover{color:var(--color-dark-accent-hover)}.dark .content blockquote{border-left-color:var(--color-dark-accent);background-color:var(--color-dark-bg-secondary);color:var(--color-dark-text-secondary);box-shadow:0 1px 3px rgba(0,0,0,.15)}.dark .post-item{border-bottom-color:var(--color-dark-border)}.dark .post-date{color:var(--color-dark-text-muted)}.dark .post-link a{color:var(--color-dark-text)}.dark .post-link a:hover{color:var(--color-dark-accent)}.dark .section-link{color:var(--color-dark-text-muted)}.dark .section-link:hover{color:var(--color-dark-text)}.dark .project-card{background-color:var(--color-dark-bg-secondary);border-color:var(--color-dark-border);box-shadow:0 1px 3px rgba(0,0,0,.15),0 1px 2px rgba(0,0,0,.1)}.dark .project-card:hover{border-color:var(--color-dark-accent);box-shadow:0 4px 12px rgba(0,0,0,.25),0 2px 4px rgba(0,0,0,.15)}.dark .footer{border-top-color:var(--color-dark-border)}.dark .footer p{color:var(--color-dark-text-muted)}.dark code{background-color:var(--color-dark-bg-secondary)}.dark pre{background-color:var(--color-dark-bg-secondary);border-color:var(--color-dark-border)}.dark .terms a{background-color:var(--color-dark-bg-secondary);border-color:var(--color-dark-border);color:var(--color-dark-text-secondary)}.dark .terms a:hover{border-color:var(--color-dark-accent);color:var(--color-dark-accent)}