﻿@font-face{font-family:"Inter";font-style:normal;font-weight:400 700;font-display:swap;src:url("/fonts/inter.woff2") format("woff2")}@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:400 500;font-display:swap;src:url("/fonts/jetbrains-mono.woff2") format("woff2")}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#1a1a2e;background:#fafafa;line-height:1.7;min-height:100vh;display:flex;flex-direction:column}a{color:#511660;text-decoration:none;transition:color .2s}a:hover{color:#3676e8}img{max-width:100%;height:auto}code{font-family:"JetBrains Mono","Fira Code",monospace;font-size:.9em;background:#f0f0f0;padding:.15em .4em;border-radius:3px}pre{background:#2b303b;color:#c0c5ce;padding:1.2em;border-radius:6px;overflow-x:auto;margin:1.5em 0}pre code{background:none;padding:0;color:inherit}.site-nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid #e5e7eb;min-height:60px}.nav-inner{max-width:800px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;min-height:60px}.nav-logo{font-weight:700;font-size:1.05rem;color:#511660;letter-spacing:-.02em;white-space:nowrap}.nav-logo:hover{color:#6495ed}.nav-links{display:flex;gap:2rem}.nav-links a{font-weight:500;font-size:.95rem;color:#6b7280}.nav-links a:hover{color:#511660}.nav-links a.active{color:#511660;border-bottom:2px solid #511660;padding-bottom:2px}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.nav-toggle span{display:block;width:22px;height:2px;background:#1a1a2e;margin:5px 0;transition:transform .2s,opacity .2s}.content{max-width:800px;margin:0 auto;padding:2.5rem 1.5rem 4rem;width:100%;flex:1}.hero{padding:3rem 0 2.5rem;border-bottom:1px solid #e5e7eb;margin-bottom:2.5rem}.hero h1{font-size:2.4rem;font-weight:700;letter-spacing:-.03em;line-height:1.15;color:#1a1a2e}.hero-subtitle{font-size:1.15rem;color:#6b7280;margin-top:.4rem;font-weight:500}.hero-summary{margin-top:1.2rem;font-size:1.05rem;max-width:600px;color:#1a1a2e;line-height:1.7}.hero-links{margin-top:1.5rem;display:flex;gap:.75rem;flex-wrap:wrap}.btn{display:inline-block;padding:.55em 1.3em;border-radius:6px;font-weight:600;font-size:.9rem;transition:all .2s;background:#511660;color:#fff}.btn:hover{background:#350e3f;color:#fff}.btn-outline{background:rgba(0,0,0,0);color:#511660;border:1.5px solid #511660}.btn-outline:hover{background:#dca4ea;color:#511660}.home-section{margin-bottom:2.5rem}.home-section h2{font-size:1.35rem;font-weight:700;margin-bottom:.8rem;color:#1a1a2e}.home-section p{color:#1a1a2e;margin-bottom:1rem}.post-list{list-style:none}.post-list li{display:flex;justify-content:space-between;align-items:baseline;padding:.65em 0;border-bottom:1px solid #e5e7eb;gap:1rem;flex-wrap:wrap}.post-list li:last-child{border-bottom:none}.post-list a{font-weight:500}.post-list time{font-size:.85rem;color:#6b7280;white-space:nowrap}.post-list .post-list-meta{display:flex;gap:.5rem;align-items:baseline}.post-list .post-desc{width:100%;font-size:.9rem;color:#6b7280}.read-more{display:inline-block;margin-top:.8rem;font-weight:600;font-size:.9rem}.muted{color:#6b7280;font-style:italic}.section-page h1,.page h1{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem}.page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.page-header time{font-size:.9rem;color:#6b7280}.post-meta{display:flex;gap:1rem;align-items:center;margin-top:.4rem}.post-meta .reading-time{font-size:.85rem;color:#6b7280}.post-meta .reading-time::before{content:"·";margin-right:.5rem}.post-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.6rem}.tag{display:inline-block;background:#dca4ea;color:#511660;padding:.2em .7em;border-radius:20px;font-size:.8rem;font-weight:500}.tag:hover{background:#d490e5;color:#511660}.tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.tag-cloud .tag{font-size:.9rem;padding:.3em .9em}.post-nav{display:flex;justify-content:space-between;margin-top:3rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;gap:1rem}.post-nav a{font-weight:500;font-size:.9rem}.post-nav-next{margin-left:auto;text-align:right}.page-body h2{font-size:1.4rem;margin:2rem 0 .8rem;font-weight:700}.page-body h3{font-size:1.15rem;margin:1.5rem 0 .6rem;font-weight:600}.page-body p{margin-bottom:1rem}.page-body ul,.page-body ol{margin:.5rem 0 1rem 1.5rem}.page-body li{margin-bottom:.35rem}.page-body blockquote{border-left:3px solid #511660;padding:.5em 1em;margin:1.5em 0;color:#6b7280;background:#f7f7f7;border-radius:0 6px 6px 0}.page-body hr{border:none;border-top:1px solid #e5e7eb;margin:2rem 0}.pagination{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.pagination a{font-weight:500;font-size:.9rem}.pagination span{font-size:.85rem;color:#6b7280}.cv-entry{margin-bottom:1.5rem;padding-left:1rem;border-left:3px solid #6495ed}.cv-entry h3{font-size:1.05rem;margin-bottom:.15rem}.cv-entry .cv-meta{font-size:.85rem;color:#6b7280;margin-bottom:.4rem}.cv-entry p,.cv-entry ul{font-size:.95rem}.cv-entry ul{margin:.3rem 0 0 1.2rem}.cv-section{margin-bottom:2.5rem}.cv-section h2{font-size:1.3rem;font-weight:700;color:#511660;padding-bottom:.4rem;border-bottom:2px solid #511660;margin-bottom:1.2rem}.cv-section ul a{text-decoration:underline;text-underline-offset:2px}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{display:inline-block;background:#dca4ea;color:#511660;padding:.3em .8em;border-radius:20px;font-size:.85rem;font-weight:500}.project-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:1.3rem;margin-bottom:1rem;transition:border-color .2s,box-shadow .2s}.project-card:hover{border-color:#6495ed;box-shadow:0 2px 12px rgba(0,0,0,.06)}.project-card h3{font-size:1.1rem;margin-bottom:.3rem}.project-card h3 a{font-weight:600}.project-card p{font-size:.93rem;color:#6b7280;margin-bottom:.5rem}.project-card .project-tags{display:flex;gap:.4rem;flex-wrap:wrap}.project-card .project-tags span{font-size:.78rem;background:#f2f2f2;padding:.2em .6em;border-radius:3px;color:#6b7280}.site-footer{border-top:1px solid #e5e7eb;padding:2rem 1.5rem;text-align:center;margin-top:auto}.footer-inner{max-width:800px;margin:0 auto}.footer-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:.8rem}.footer-links a{font-size:.9rem;color:#6b7280;font-weight:500}.footer-links a:hover{color:#511660}.site-footer p{font-size:.8rem;color:#6b7280}@media (max-width: 640px){.hero h1{font-size:1.8rem}.hero-subtitle{font-size:1rem}.content{padding:1.5rem 1rem 3rem}.cv-entry{padding-left:.75rem}.nav-toggle{display:block}.nav-links{display:none;flex-direction:column;gap:0;position:absolute;top:60px;left:0;right:0;background:rgba(255,255,255,.98);backdrop-filter:blur(12px);border-bottom:1px solid #e5e7eb;padding:.5rem 1.5rem 1rem}.nav-links a{display:block;padding:.6rem 0;border-bottom:1px solid #e5e7eb}.nav-links a:last-child{border-bottom:none}.nav-links a.active{border-bottom-color:#e5e7eb}.nav-toggle.open+.nav-links{display:flex}}.theme-toggle{background:none;border:none;cursor:pointer;padding:.4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:color .2s}.theme-toggle:hover{color:#511660}.theme-toggle svg{width:20px;height:20px}.theme-toggle .icon-moon{display:block}.theme-toggle .icon-sun{display:none}[data-theme=dark]{--bg: #1a1a2e;--surface: #222240;--text: #e4e4ef;--text-muted: #9a9ab0;--primary: #c084fc;--accent: #7cacf8;--border: #333355;--hover: rgba(192, 132, 252, 0.12)}[data-theme=dark] body{background:var(--bg);color:var(--text)}[data-theme=dark] a{color:var(--primary)}[data-theme=dark] a:hover{color:var(--accent)}[data-theme=dark] code{background:rgba(255,255,255,.06)}[data-theme=dark] .site-nav{background:rgba(34,34,64,.92);border-bottom-color:var(--border)}[data-theme=dark] .nav-logo{color:var(--primary)}[data-theme=dark] .nav-logo:hover{color:var(--accent)}[data-theme=dark] .nav-links a{color:var(--text-muted)}[data-theme=dark] .nav-links a:hover{color:var(--primary)}[data-theme=dark] .nav-links a.active{color:var(--primary);border-bottom-color:var(--primary)}[data-theme=dark] .nav-toggle span{background:var(--text)}[data-theme=dark] .theme-toggle{color:var(--text-muted)}[data-theme=dark] .theme-toggle:hover{color:var(--primary)}[data-theme=dark] .theme-toggle .icon-moon{display:none}[data-theme=dark] .theme-toggle .icon-sun{display:block}[data-theme=dark] .hero{border-bottom-color:var(--border)}[data-theme=dark] .hero h1{color:var(--text)}[data-theme=dark] .hero-subtitle{color:var(--text-muted)}[data-theme=dark] .hero-summary{color:var(--text)}[data-theme=dark] .btn{background:var(--primary);color:var(--bg)}[data-theme=dark] .btn:hover{background:#d4acfd;color:var(--bg)}[data-theme=dark] .btn-outline{color:var(--primary);border-color:var(--primary);background:rgba(0,0,0,0)}[data-theme=dark] .btn-outline:hover{background:var(--hover);color:var(--primary)}[data-theme=dark] .home-section h2{color:var(--text)}[data-theme=dark] .home-section p{color:var(--text)}[data-theme=dark] .post-list li{border-bottom-color:var(--border)}[data-theme=dark] .post-list time{color:var(--text-muted)}[data-theme=dark] .post-list .post-desc{color:var(--text-muted)}[data-theme=dark] .page-header{border-bottom-color:var(--border)}[data-theme=dark] .post-meta .reading-time{color:var(--text-muted)}[data-theme=dark] .tag{background:var(--hover);color:var(--primary)}[data-theme=dark] .tag:hover{background:rgba(192,132,252,.2)}[data-theme=dark] .post-nav{border-top-color:var(--border)}[data-theme=dark] .pagination{border-top-color:var(--border)}[data-theme=dark] .pagination span{color:var(--text-muted)}[data-theme=dark] .page-body blockquote{border-left-color:var(--primary);background:rgba(255,255,255,.03);color:var(--text-muted)}[data-theme=dark] .page-body hr{border-top-color:var(--border)}[data-theme=dark] .section-page h1,[data-theme=dark] .page h1{color:var(--text)}[data-theme=dark] .cv-entry{border-left-color:var(--accent)}[data-theme=dark] .cv-entry .cv-meta{color:var(--text-muted)}[data-theme=dark] .cv-section h2{color:var(--primary);border-bottom-color:var(--primary)}[data-theme=dark] .skill-tag{background:var(--hover);color:var(--primary)}[data-theme=dark] .project-card{background:var(--surface);border-color:var(--border)}[data-theme=dark] .project-card:hover{border-color:var(--accent);box-shadow:0 2px 12px rgba(0,0,0,.2)}[data-theme=dark] .project-card p{color:var(--text-muted)}[data-theme=dark] .project-card .project-tags span{background:rgba(255,255,255,.06);color:var(--text-muted)}[data-theme=dark] .site-footer{border-top-color:var(--border)}[data-theme=dark] .footer-links a{color:var(--text-muted)}[data-theme=dark] .footer-links a:hover{color:var(--primary)}[data-theme=dark] .site-footer p{color:var(--text-muted)}@media (max-width: 640px){[data-theme=dark] .nav-links{background:rgba(34,34,64,.98);border-bottom-color:var(--border)}[data-theme=dark] .nav-links a{border-bottom-color:var(--border)}}