:root,[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #e8e8e8;--bg-card: #ffffff;--bg-hover: #f0f0f0;--card-outline: #ffffff;--text-primary: #1a1a1a;--text-secondary: #555555;--text-muted: #888888;--border-color: #d0d0d0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.08);--shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.15);--header-bg: rgba(255, 255, 255, 0.95);--overlay-bg: rgba(245, 245, 245, 0.95);--overlay-gradient: linear-gradient(transparent, rgba(245, 245, 245, 0.98));--bg-blur-filter: grayscale(100%) blur(8px) brightness(1.2);--bg-overlay-opacity: 0.75}[data-theme=dark]{--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-card: #1a1a1a;--bg-hover: #242424;--card-outline: #1a1a1a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #666666;--border-color: #2a2a2a;--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);--shadow-md: 0 4px 6px rgba(0, 0, 0, 0.4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.5);--header-bg: rgba(10, 10, 10, 0.9);--overlay-bg: rgba(10, 10, 10, 0.95);--overlay-gradient: linear-gradient(transparent, rgba(10, 10, 10, 0.95));--bg-blur-filter: grayscale(100%) blur(8px);--bg-overlay-opacity: 0.8}@media(prefers-color-scheme: dark){:root:not([data-theme]){--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-card: #1a1a1a;--bg-hover: #242424;--card-outline: #1a1a1a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #666666;--border-color: #2a2a2a;--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);--shadow-md: 0 4px 6px rgba(0, 0, 0, 0.4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.5);--header-bg: rgba(10, 10, 10, 0.9);--overlay-bg: rgba(10, 10, 10, 0.95);--overlay-gradient: linear-gradient(transparent, rgba(10, 10, 10, 0.95));--bg-blur-filter: grayscale(100%) blur(8px);--bg-overlay-opacity: 0.8}}*,*::before,*::after{box-sizing:border-box}html{font-size:18px;scroll-behavior:smooth}body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:400;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body::before{content:"";position:fixed;top:-20px;left:-20px;right:-20px;bottom:-20px;background-image:url("/assets/images/bg-city-rain.jpg");background-size:cover;background-position:center;filter:var(--bg-blur-filter);z-index:-2}body::after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-primary);opacity:var(--bg-overlay-opacity);z-index:-1}h1,h2,h3,h4,h5,h6{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:600;line-height:1.3;color:var(--text-primary);margin-top:0}h1{font-size:3rem;margin-bottom:1rem}h2{font-size:2rem;margin-bottom:.75rem}h3{font-size:1.5rem;margin-bottom:.5rem}h4{font-size:1.25rem;margin-bottom:.5rem}p{color:var(--text-secondary);margin-bottom:1.5rem}a{color:#a31621;text-decoration:none;transition:color .2s ease}a:hover{color:#7d111a}img{max-width:100%}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--header-bg);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:16px 0}.site-header .header-content{position:relative}.header-content{display:flex;justify-content:space-between;align-items:center;padding:0 50px}.site-title{font-size:1.25rem;font-weight:600;color:#a31621 !important;text-decoration:none;transition:color .2s ease}.site-title:hover{color:#7d111a !important}.header-tagline{position:absolute;left:50%;transform:translateX(-50%);font-size:.95rem;font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.header-right{display:flex;align-items:center;gap:24px}.site-nav{display:flex;gap:32px}.site-nav a{color:var(--text-secondary);font-size:.95rem;font-weight:500;transition:color .2s ease}.site-nav a:hover{color:var(--text-primary)}.theme-toggle{background:rgba(0,0,0,0);border:1px solid var(--border-color);border-radius:4px;padding:8px 10px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{color:var(--text-primary);border-color:var(--text-muted);background:var(--bg-hover)}.theme-toggle i{font-size:1rem}.theme-toggle #theme-icon-light,.theme-toggle #theme-icon-dark{display:none}.hero{padding:160px 24px 60px;max-width:900px;margin:0 auto}.hero h1{font-size:3.5rem;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.hero h1 .name-accent{color:#a31621}.hero .subtitle{font-size:1.25rem;color:var(--text-secondary);max-width:600px;line-height:1.7}.featured-section{padding:40px 24px 80px;max-width:1200px;margin:0 auto}.featured-section .section-title{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:32px}.featured-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:24px}@media(max-width: 768px){.featured-grid{grid-template-columns:1fr}}.featured-card{position:relative;border-radius:8px;background:var(--bg-card);border:1px solid var(--border-color);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}.featured-card::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:8px;border:10px solid var(--card-outline);pointer-events:none;z-index:5}.featured-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.featured-card:hover .featured-image img{transform:scale(1.05)}.featured-card a{text-decoration:none;color:inherit;display:block}.featured-image{height:280px;overflow:hidden;background:var(--bg-secondary);position:relative;border-radius:8px;margin:10px;margin-bottom:0}.featured-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,opacity .4s ease}.featured-image .img-default{position:relative;z-index:1}.featured-image .img-hover{position:absolute;top:0;left:0;z-index:2;opacity:0}.featured-card:hover .featured-image .img-hover{opacity:1}.featured-content{padding:24px;padding-top:16px;position:relative}.featured-content h3{font-size:1.25rem;margin-bottom:8px;color:var(--text-primary)}.featured-content p{font-size:.95rem;color:var(--text-secondary);margin-bottom:12px;line-height:1.5}.featured-content .meta{font-size:.85rem;color:var(--text-muted)}.featured-card .title-tab{position:absolute;top:248px;left:0;z-index:10;background:var(--bg-card);padding:10px 24px 10px 24px;border-radius:0 8px 0 0}.featured-card .title-tab::after{content:"";position:absolute;top:-12px;left:0;width:12px;height:12px;background:radial-gradient(circle at 100% 0, transparent 12px, var(--bg-card) 12px)}.featured-card .title-tab::before{content:"";position:absolute;top:30px;right:-12px;width:12px;height:12px;background:radial-gradient(circle at 100% 0, transparent 12px, var(--bg-card) 12px)}.featured-card .title-tab h3{font-size:1.15rem;margin:0;color:var(--text-primary);font-weight:600}.projects-page{padding:120px 24px 80px;max-width:1200px;margin:0 auto}.projects-page h1{margin-bottom:24px}.filter-chips{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px}.filter-chip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;padding:8px 20px;font-size:.9rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.filter-chip:hover{border-color:#a31621;color:var(--text-primary)}.filter-chip.active{background:#a31621;border-color:#a31621;color:#fff}.projects-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px}@media(max-width: 1024px){.projects-grid{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 480px){.projects-grid{grid-template-columns:1fr}}.project-card{position:relative;border-radius:6px;background:var(--bg-card);border:1px solid var(--border-color);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease,opacity .5s ease}.project-card.filtering-out{opacity:0;pointer-events:none}.project-card.filtered-out{display:none}.project-card.filtering-in{opacity:0}.project-card::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:6px;border:10px solid var(--card-outline);pointer-events:none;z-index:5}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.project-card:hover .project-image img{transform:scale(1.05)}.project-card a{text-decoration:none;color:inherit;display:block}.project-image{height:200px;overflow:hidden;background:var(--bg-secondary);position:relative;border-radius:6px;margin:10px;margin-bottom:0}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,opacity .4s ease}.project-image .img-default{position:relative;z-index:1}.project-image .img-hover{position:absolute;top:0;left:0;z-index:2;opacity:0}.project-card:hover .project-image .img-hover{opacity:1}.project-content{padding:20px;padding-top:14px;position:relative}.project-content h3{font-size:1.1rem;margin-bottom:6px;color:var(--text-primary)}.project-content p{font-size:.9rem;color:var(--text-secondary);margin-bottom:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.project-card .title-tab{position:absolute;top:172px;left:0;z-index:10;background:var(--bg-card);padding:8px 20px 8px 20px;border-radius:0 6px 0 0}.project-card .title-tab::after{content:"";position:absolute;top:-10px;left:0;width:10px;height:10px;background:radial-gradient(circle at 100% 0, transparent 10px, var(--bg-card) 10px)}.project-card .title-tab::before{content:"";position:absolute;bottom:1px;right:-10px;width:10px;height:10px;background:radial-gradient(circle at 100% 0, transparent 10px, var(--bg-card) 10px)}.project-card .title-tab h3{font-size:1rem;margin:0;color:var(--text-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.category-tag{display:inline-block;font-size:.75rem;font-weight:500;color:#a31621;background:rgba(163,22,33,.1);padding:4px 10px;border-radius:4px;margin-bottom:10px}.project-hero{position:relative;height:60vh;min-height:400px;max-height:600px;margin-top:73px;overflow:hidden;background:var(--bg-secondary)}.project-hero img{width:100%;height:100%;object-fit:cover}.project-hero .overlay{position:absolute;bottom:0;left:0;right:0;padding:80px 24px 40px;background:var(--overlay-gradient)}.project-hero h1{max-width:900px;margin:0 auto 16px;font-size:2.5rem}.project-hero .project-meta{max-width:900px;margin:0 auto;display:flex;flex-wrap:wrap;gap:24px;color:var(--text-secondary);font-size:.95rem}.project-body{max-width:800px;margin:0 auto;padding:60px 24px 80px}.project-body h2{margin-top:48px;margin-bottom:16px;font-size:1.5rem}.project-body h2:first-child{margin-top:0}.project-body ul,.project-body ol{color:var(--text-secondary);padding-left:24px;margin-bottom:1.5rem}.project-body ul li,.project-body ol li{margin-bottom:8px}.project-gallery{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:20px;margin:48px 0}.project-gallery .gallery-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:16px}@media(max-width: 480px){.project-gallery .gallery-grid{grid-template-columns:1fr}}.project-gallery .gallery-grid:has(.gallery-item:only-child){grid-template-columns:1fr;max-width:50%;margin:0 auto}@media(max-width: 480px){.project-gallery .gallery-grid:has(.gallery-item:only-child){max-width:100%}}.project-gallery .gallery-item{height:200px;overflow:hidden;border-radius:4px;background:var(--bg-secondary)}.project-gallery .gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-gallery .gallery-item img:hover{transform:scale(1.05)}.blog-page{padding:120px 24px 80px;max-width:900px;margin:0 auto}.blog-page h1{margin-bottom:48px}.blog-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:24px}@media(max-width: 768px){.blog-grid{grid-template-columns:1fr}}.blog-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:24px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}.blog-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 0 1px rgba(163,22,33,.2);border-color:rgba(163,22,33,.3)}.blog-card h3{font-size:1.25rem;margin-bottom:12px}.blog-card h3 a{color:var(--text-primary)}.blog-card h3 a:hover{color:#a31621}.blog-card p{font-size:.95rem;margin-bottom:16px;line-height:1.5}.blog-card .date{font-size:.85rem;color:var(--text-muted)}.post-hero{position:relative;height:50vh;min-height:350px;max-height:500px;margin-top:73px;overflow:hidden}.post-hero img{width:100%;height:100%;object-fit:cover}.post-hero .overlay{position:absolute;bottom:0;left:0;right:0;padding:80px 24px 40px;background:var(--overlay-gradient)}.post-hero .post-hero-content{max-width:700px;margin:0 auto}.post-hero .post-hero-content .date{color:var(--text-muted);font-size:.9rem;margin-bottom:12px}.post-hero .post-hero-content h1{font-size:2.5rem;margin:0}.blog-post{max-width:700px;margin:0 auto;padding:60px 24px 80px}.blog-post header{margin-bottom:48px;padding-top:80px}.blog-post header .date{color:var(--text-muted);font-size:.9rem;margin-bottom:16px}.blog-post header h1{font-size:2.5rem;margin-bottom:24px}.blog-post .lead{font-size:1.25rem;color:var(--text-secondary);line-height:1.6;margin-bottom:48px}.blog-post .post-content h2{margin-top:48px;margin-bottom:16px}.blog-post .post-content h2:first-child{margin-top:0}.blog-post .post-footer{margin-top:60px;padding-top:32px;border-top:1px solid var(--border-color)}.blog-post .post-footer a{color:var(--text-secondary)}.blog-post .post-footer a:hover{color:var(--text-primary)}footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:48px 24px;margin-top:80px}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}@media(max-width: 768px){.footer-content{flex-direction:column;gap:24px;text-align:center}}.copy{color:var(--text-muted);font-size:.9rem;margin:0}.copy small{font-size:inherit}.social-links{display:flex;gap:20px}.social-links a{color:var(--text-secondary);font-size:1.25rem;transition:color .2s ease}.social-links a:hover{color:var(--text-primary)}.about-hero{position:relative;height:50vh;min-height:350px;max-height:500px;margin-top:73px;overflow:hidden}.about-hero img{width:100%;height:100%;object-fit:cover}.about-hero .overlay{position:absolute;bottom:0;left:0;right:0;padding:60px 24px 40px;background:var(--overlay-gradient)}.about-hero .overlay h1{max-width:800px;margin:0 auto;font-size:2.5rem}.about-body{max-width:700px;margin:0 auto;padding:60px 24px 80px}.about-body .lead{font-size:1.35rem;color:var(--text-primary);line-height:1.6;margin-bottom:32px}.about-body h2{margin-top:48px;margin-bottom:16px;font-size:1.5rem}.post-headline,.headline{font-size:2.5rem;margin-bottom:8px;color:var(--text-primary)}.post-description{color:var(--text-secondary);font-size:1.1rem;margin-bottom:0}.links{display:none}main{min-height:calc(100vh - 200px)}pre,code{font-size:.9rem;border-radius:4px;background:var(--bg-secondary)}pre{padding:1em;overflow-x:auto;border:1px solid var(--border-color)}code{padding:.2em .4em}pre code{padding:0;background:rgba(0,0,0,0)}blockquote{border-left:3px solid #a31621;padding-left:1.5em;margin:1.5em 0;color:var(--text-secondary);font-style:italic}.view-all{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.95rem;margin-top:32px;transition:color .2s ease}.view-all:hover{color:var(--text-primary)}.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.lightbox.active{opacity:1;visibility:visible}.lightbox-content{max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.5)}.lightbox-close{position:absolute;top:20px;right:24px;background:rgba(0,0,0,0);border:none;color:#fff;font-size:2.5rem;cursor:pointer;opacity:.7;transition:opacity .2s ease;line-height:1}.lightbox-close:hover{opacity:1}.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:hsla(0,0%,100%,.1);border:none;color:#fff;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s ease,background .2s ease}.lightbox-prev:hover,.lightbox-next:hover{opacity:1;background:hsla(0,0%,100%,.2)}.lightbox-prev i,.lightbox-next i{font-size:1.25rem}.lightbox-prev{left:24px}.lightbox-next{right:24px}.gallery-item img{cursor:pointer}.gallery-item img:hover{opacity:.9}pre.highlight{background-color:#fff;padding:7px 7px 7px 10px;-moz-box-shadow:1px 1px rgba(0,0,0,.1);-webkit-box-shadow:1px 1px rgba(0,0,0,.1);box-shadow:1px 1px rgba(0,0,0,.1);border-radius:3px;margin:20px 0 20px 0;overflow:auto}code{font-family:"Bitstream Vera Sans Mono","Courier",monospace;color:#000;background-color:#fff;border-radius:1px}.highlight,.highlight .w{color:#586e75}.highlight .err{color:#002b36;background-color:#dc322f}.highlight .c,.highlight .cd,.highlight .cm,.highlight .c1,.highlight .cs{color:#657b83}.highlight .cp{color:#b58900}.highlight .nt{color:#b58900}.highlight .o,.highlight .ow{color:#93a1a1}.highlight .p,.highlight .pi{color:#93a1a1}.highlight .gi{color:#859900}.highlight .gd{color:#dc322f}.highlight .gh{color:#268bd2;background-color:#002b36;font-weight:bold}.highlight .k,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kv{color:#6c71c4}.highlight .kc{color:#cb4b16}.highlight .kt{color:#cb4b16}.highlight .kd{color:#cb4b16}.highlight .s,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .s2,.highlight .sh,.highlight .sx,.highlight .s1{color:#859900}.highlight .sr{color:#2aa198}.highlight .si{color:#d33682}.highlight .se{color:#d33682}.highlight .nn{color:#b58900}.highlight .nc{color:#b58900}.highlight .no{color:#b58900}.highlight .na{color:#268bd2}.highlight .m,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .il,.highlight .mo,.highlight .mb,.highlight .mx{color:#859900}.highlight .ss{color:#859900}@media(prefers-color-scheme: dark){pre.highlight{background-color:#263238;padding:7px 7px 7px 10px;-moz-box-shadow:3px 3px rgba(0,0,0,.1);-webkit-box-shadow:3px 3px rgba(0,0,0,.1);box-shadow:3px 3px rgba(0,0,0,.1);border-radius:3px;margin:20px 0 20px 0;overflow:auto}code{font-family:"Bitstream Vera Sans Mono","Courier",monospace;color:#c9d1d9;background-color:#263238;border-radius:1px}.highlight .c,.highlight .cd{color:#75715e;font-style:italic}.highlight .cm{color:#75715e;font-style:italic}.highlight .c1{color:#75715e;font-style:italic}.highlight .cp{color:#75715e;font-weight:bold}.highlight .cs{color:#75715e;font-weight:bold;font-style:italic}.highlight .err{color:#960050;background-color:#1e0010}.highlight .gi{color:#fff;background-color:#324932}.highlight .gd{color:#fff;background-color:#493131}.highlight .ge{color:#000;font-style:italic}.highlight .gr{color:#a00}.highlight .gt{color:#a00}.highlight .gh{color:#999}.highlight .go{color:#888}.highlight .gp{color:#555}.highlight .gs{font-weight:bold}.highlight .gu{color:#aaa}.highlight .k,.highlight .kv{color:#66d9ef;font-weight:bold}.highlight .kc{color:#66d9ef;font-weight:bold}.highlight .kd{color:#66d9ef;font-weight:bold}.highlight .kp{color:#66d9ef;font-weight:bold}.highlight .kr{color:#66d9ef;font-weight:bold}.highlight .kt{color:#66d9ef;font-weight:bold}.highlight .kn{color:#f92672;font-weight:bold}.highlight .ow{color:#f92672;font-weight:bold}.highlight .o{color:#f92672;font-weight:bold}.highlight .mf{color:#ae81ff}.highlight .mh{color:#ae81ff}.highlight .il{color:#ae81ff}.highlight .mi{color:#ae81ff}.highlight .mo{color:#ae81ff}.highlight .m,.highlight .mb,.highlight .mx{color:#ae81ff}.highlight .se{color:#ae81ff}.highlight .sb{color:#e6db74}.highlight .sc{color:#e6db74}.highlight .sd{color:#e6db74}.highlight .s2{color:#e6db74}.highlight .sh{color:#e6db74}.highlight .si{color:#e6db74}.highlight .sx{color:#e6db74}.highlight .sr{color:#e6db74}.highlight .s1{color:#e6db74}.highlight .ss{color:#e6db74}.highlight .s{color:#e6db74}.highlight .na{color:#a6e22e}.highlight .nc{color:#a6e22e;font-weight:bold}.highlight .nd{color:#a6e22e;font-weight:bold}.highlight .ne{color:#a6e22e;font-weight:bold}.highlight .nf{color:#a6e22e;font-weight:bold}.highlight .no{color:#66d9ef}.highlight .bp{color:#f8f8f2}.highlight .nb{color:#f8f8f2}.highlight .ni{color:#f8f8f2}.highlight .nn{color:#f8f8f2}.highlight .vc{color:#f8f8f2}.highlight .vg{color:#f8f8f2}.highlight .vi{color:#f8f8f2}.highlight .nv{color:#f8f8f2}.highlight .w{color:#f8f8f2}.highlight .nl{color:#f8f8f2;font-weight:bold}.highlight .nt{color:#f92672}.highlight{color:#f8f8f2;background-color:#49483e}}/*# sourceMappingURL=main.css.map */