:root{--primary-color:#121212;--accent-color:#3182ce;--bg-color:#ffffff;--container-bg:rgba(255, 255, 255, 0.4);--text-color:#292929;--border-color:rgba(0, 0, 0, 0.08);--font-main:system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;--shadow-md:0 8px 32px 0 rgba(31, 38, 135, 0.1);--shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);--radius:12px}[data-theme=dark]{--primary-color:#f7fafc;--accent-color:#63b3ed;--bg-color:#1a202c;--container-bg:rgba(26, 32, 44, 0.6);--text-color:#e2e8f0;--border-color:rgba(255, 255, 255, 0.1);--shadow-md:0 8px 32px 0 rgba(0, 0, 0, 0.4);--shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -2px rgba(0, 0, 0, 0.3)}*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden}body{margin:0;padding:0;font-family:var(--font-main);background-color:var(--bg-color);background-image:var(--bg-image);min-height:100vh;color:var(--text-color);line-height:1.6}a{color:var(--accent-color);text-decoration:none}a:hover{text-decoration:none}h1,h2,h3{margin-top:0;color:var(--primary-color);letter-spacing:-.025em;line-height:1.2}ul{list-style:none;padding:0;margin:0}.turbo-progress-bar{background:var(--accent-color) !important;height:3px}.icon{width:1em;height:1em;display:inline-block;vertical-align:-.125em}.site-wrapper{display:grid;grid-template-columns:1fr;grid-template-areas:"tags" "main" "sidebar";gap:1rem;padding:2rem 1rem;max-width:1200px;margin:0 auto;width:100%}.site-wrapper.no-sidebar{grid-template-areas:"tags" "main"}.site-main{grid-area:main;min-width:0}.blog-grid{display:grid;grid-template-columns:1fr;gap:2rem}.site-sidebar{grid-area:sidebar}@media(min-width:768px){.site-wrapper{grid-template-columns:2.5fr 1fr;grid-template-areas:"tags tags" "main sidebar";gap:4rem}.site-sidebar{position:sticky;top:6rem;height:fit-content;border-left:1px solid var(--border-color);padding-left:2rem;max-width:320px;width:100%}.site-wrapper.no-sidebar{grid-template-columns:1fr;grid-template-areas:"tags" "main";row-gap:2rem}.blog-grid{grid-template-columns:repeat(2,1fr)}}.sticky-top-bar{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:none;border-bottom:1px solid var(--border-color);width:100%}.header-inner{max-width:1200px;margin:0 auto;padding:.75rem 1rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem}.site-branding h1{margin:0;font-size:1.25rem}.theme-toggle{background:0 0;border:none;color:var(--text-color);cursor:pointer;font-size:1.1rem;padding:.5rem;border-radius:50%;transition:background-color .2s;display:flex;align-items:center;justify-content:center;margin-left:auto}.menu-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.menu-backdrop.active{opacity:1;visibility:visible}body.no-scroll{overflow:hidden}.site-nav{position:fixed;top:0;right:0;width:75%;max-width:300px;height:100vh;background:var(--bg-color);border-left:1px solid var(--border-color);border-bottom:none;display:flex;flex-direction:column;padding:5rem 0 0;margin:0;z-index:1001;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto}.site-nav.active{transform:translateX(0)}.site-nav>ul{display:flex;flex-direction:column;width:100%;gap:0}.site-nav li{width:100%;border-bottom:1px solid var(--border-color)}.site-nav a{display:flex;justify-content:space-between;align-items:center;padding:1rem;color:var(--text-color);font-weight:600;width:100%;border-radius:0;transition:color .2s,background-color .2s}.site-nav a:hover{background-color:rgba(0,0,0,5%);color:var(--accent-color);text-decoration:none}.site-nav a.active{color:var(--accent-color);background-color:rgba(0,0,0,5%)}.menu-toggle{display:block;background:0 0;border:none;color:var(--text-color);font-size:1.25rem;cursor:pointer;padding:.5rem;margin-left:.5rem;position:relative;z-index:1002}.submenu{display:none;background:rgba(0,0,0,3%);padding-left:0}.has-submenu.active .submenu{display:block}.submenu li{border-bottom:1px solid var(--border-color)}.submenu li:last-child{border-bottom:none}.submenu a{padding-left:2rem;font-size:.95rem;font-weight:500}@media(min-width:768px){.header-inner{flex-wrap:nowrap}.menu-toggle{display:none}body.no-scroll{overflow:visible}.menu-backdrop{display:none}.site-nav{position:static;display:flex;align-items:center;width:auto;max-width:none;height:auto;background:0 0;border:none;box-shadow:none;padding:0;margin-left:auto;margin-right:1.5rem;transform:none;backdrop-filter:none;-webkit-backdrop-filter:none;overflow-y:visible}.site-nav>ul{flex-direction:row;gap:2rem;align-items:center}.site-nav li{width:auto;border:none;position:relative}.site-nav a{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 0;width:auto;border-radius:0;font-weight:500;position:relative}.site-nav a:hover{background-color:transparent;color:var(--primary-color);text-decoration:none}.site-nav a.active{color:var(--primary-color);background-color:transparent}.site-nav>ul>li>a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--primary-color);transition:width .3s ease}.site-nav>ul>li>a:hover::after{width:100%}.site-nav>ul>li>a.active::after{width:100%}.submenu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:200px;background:var(--container-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius);padding:.5rem;box-shadow:var(--shadow-lg);z-index:1000}.has-submenu:hover .submenu{display:block}.submenu a{padding:.75rem 1rem;border-radius:var(--radius);display:block}.submenu a:hover{background-color:rgba(0,0,0,5%)}.submenu li{border-bottom:none}}[data-theme=dark] .sticky-top-bar{background:rgba(26,32,44,.8)}.site-footer{padding:3rem 2rem 2rem;background:rgba(255,255,255,.2);backdrop-filter:blur(10px);color:var(--text-color);border-top:1px solid var(--border-color);width:100%}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;max-width:1200px;margin:0 auto;padding-bottom:2rem;text-align:left}.footer-branding h3{font-size:1.5rem;margin-bottom:.5rem;font-weight:800;letter-spacing:-.025em}.footer-branding p{opacity:.7;font-size:.9rem;line-height:1.5;max-width:300px}.footer-links h4,.footer-social h4{font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;color:var(--primary-color);font-weight:700;opacity:.8}.footer-links ul{display:flex;flex-direction:column;gap:.5rem}.footer-links a{color:var(--text-color);opacity:.7;transition:all .2s;font-size:.95rem}.footer-links a:hover{opacity:1;color:var(--accent-color);text-decoration:none;padding-left:5px}.social-icons{display:flex;gap:1rem}.social-icons a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--container-bg);border:1px solid var(--border-color);color:var(--text-color);transition:all .2s}.social-icons a:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:translateY(-3px)}.footer-bottom{border-top:1px solid var(--border-color);padding-top:2rem;text-align:center;font-size:.85rem;opacity:.6}[data-theme=dark] .site-footer{background:rgba(0,0,0,.2)}.widget{background:0 0;padding:0;margin-bottom:3rem;box-shadow:none}.widget h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-color);opacity:.6;margin-bottom:1.5rem;font-weight:700}.widget ul{display:flex;flex-direction:column}.widget ul li a{display:block;padding:.75rem 0;color:var(--text-color);border-bottom:1px solid var(--border-color);transition:all .2s ease;font-size:.95rem}.widget ul li a:hover{color:var(--accent-color);padding-left:.5rem;text-decoration:none;border-color:var(--accent-color)}.profile-image{width:100px;height:100px;border-radius:50%;margin-bottom:1rem;object-fit:cover}.featured-project-card{display:block;text-decoration:none;position:relative;border-radius:var(--radius);overflow:hidden}.featured-project-image{width:100%;height:180px;object-fit:cover;border-radius:0;margin-bottom:0;transition:transform .3s ease;display:block}.featured-project-card:hover .featured-project-image{transform:scale(1.05)}.featured-project-title{font-size:1rem;font-weight:600;color:#fff;margin:0;position:absolute;bottom:0;left:0;width:100%;padding:4rem 1rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);text-shadow:0 1px 3px rgba(0,0,0,.5)}.featured-project-card:hover .featured-project-title{color:#fff}.tag-bar{grid-area:tags;padding:0 0 1rem;width:100%;min-width:0;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.tag-scroll{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;flex:1}.tag-scroll::-webkit-scrollbar{display:none}.tag-pill{background:rgba(0,0,0,5%);border:none;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;color:var(--text-color);cursor:pointer;white-space:nowrap;transition:all .2s ease;font-family:var(--font-main);display:inline-block;text-decoration:none}.tag-pill:hover{background:rgba(0,0,0,.1);text-decoration:none}.tag-pill.active{background:var(--primary-color);color:#fff}.tag-search{background:0 0;border:none;color:var(--text-color);font-size:1rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tag-search:hover{background:rgba(0,0,0,5%);color:var(--accent-color)}.search-expandable{display:flex;align-items:center;background:0 0;border-radius:24px;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.search-expandable.active{background:var(--container-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-color:var(--border-color);padding-left:1rem;box-shadow:var(--shadow-md)}.search-input{border:none;background:0 0;outline:none;width:0;padding:0;opacity:0;transition:all .3s ease;color:var(--text-color);font-family:var(--font-main);font-size:.9rem}.search-expandable.active .search-input{width:180px;opacity:1}[data-theme=dark] .tag-pill{background:rgba(255,255,255,5%)}[data-theme=dark] .tag-pill:hover{background:rgba(255,255,255,.1)}[data-theme=dark] .tag-pill.active{color:#1a202c}[data-theme=dark] .tag-search:hover{background:rgba(255,255,255,.1)}.blog-post{background:var(--container-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);margin-bottom:0;display:flex;flex-direction:column;border-radius:var(--radius);box-shadow:none;overflow:hidden;border:1px solid var(--border-color)}.blog-post:hover{transform:none;box-shadow:none}.post-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.read-more{margin-top:auto;align-self:flex-start}.blog-post:not(.post-detail) h2{font-size:1.5rem;margin-bottom:.5rem;font-weight:800;line-height:1.2;letter-spacing:-.025em}.blog-post:not(.post-detail) h2 a{color:inherit;text-decoration:none;transition:color .2s}.blog-post:not(.post-detail) h2 a:hover{color:var(--accent-color)}.blog-post:not(.post-detail) .meta{font-size:.75rem;color:var(--text-color);opacity:.6;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:flex;align-items:center}.blog-post:not(.post-detail) .meta::before{content:'';display:inline-block;width:24px;height:1px;background-color:var(--accent-color);margin-right:.75rem}.blog-post.post-detail{background:0 0;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:0}.blog-post.post-detail .post-content{padding-left:0;padding-right:0}.post-header{margin-bottom:2rem;border-bottom:1px solid var(--border-color);padding-bottom:1.5rem}.post-header h1{font-size:2.5rem;margin-bottom:1rem;line-height:1.2}.post-meta-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.meta-info{display:flex;gap:1.5rem;color:var(--text-color);opacity:.7;font-size:.9rem}.meta-item{display:flex;align-items:center;gap:.5rem}.btn-share-post{background:0 0;border:1px solid var(--border-color);color:var(--text-color);padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.btn-share-post:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.post-navigation{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color);gap:1rem}.nav-link{display:flex;flex-direction:column;text-decoration:none;max-width:45%}.nav-link span{font-size:.85rem;color:var(--text-color);opacity:.6;margin-bottom:.25rem}.nav-link strong{color:var(--primary-color);font-size:1rem;line-height:1.4;transition:color .2s}.nav-link:hover strong{color:var(--accent-color)}.nav-next{text-align:right;align-items:flex-end;margin-left:auto}.related-section{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border-color)}.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:1.5rem}.related-card{display:flex;flex-direction:column;text-decoration:none;position:relative;border-radius:var(--radius);overflow:hidden;background:var(--container-bg);border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease;min-height:200px}.related-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.related-image{width:100%;height:100%;position:absolute;top:0;left:0;object-fit:cover;border-radius:0;margin-bottom:0;transition:transform .3s ease}.related-card:hover .related-image{transform:scale(1.05)}.related-card h4{font-size:1.1rem;margin:0;color:var(--primary-color);transition:color .2s;padding:1.5rem}.related-card:hover h4{color:var(--accent-color)}.related-card p{font-size:.9rem;color:var(--text-color);opacity:.8;margin:0;padding:0 1.5rem 1.5rem}.related-image+h4{position:absolute;bottom:0;left:0;width:100%;padding:4rem 1rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.related-card:hover .related-image+h4{color:#fff}.related-image~p{display:none}.post-image{width:100%;height:250px;object-fit:cover;border-radius:0}.post-image-large{width:100%;height:400px;object-fit:cover}.project-meta{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;margin:1rem 0 2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.project-tech-stack{display:flex;gap:.5rem;flex-wrap:wrap;margin-right:auto}.project-meta .btn{flex:initial;width:auto;padding:.4rem 1rem;font-size:.85rem}.project-carousel{width:100%;max-width:100%;overflow-x:auto;margin-bottom:2rem;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;scroll-snap-type:x mandatory;scroll-behavior:smooth}.project-carousel::-webkit-scrollbar{display:none}.carousel-track{display:flex;gap:1rem;padding:.5rem 0 1.5rem;width:max-content}.carousel-image{height:400px;width:auto;max-width:85vw;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-md);scroll-snap-align:center}@media(min-width:768px){.blog-post.span-2{grid-column:span 2}.carousel-image{height:450px}}.post-content{font-size:1.1rem;line-height:1.8}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin-top:2.5rem;margin-bottom:1rem;color:var(--primary-color);font-weight:700;line-height:1.3}.post-content h1{font-size:2.25rem}.post-content h2{font-size:1.8rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.post-content h3{font-size:1.5rem}.post-content h4{font-size:1.25rem}.post-content h5{font-size:1.1rem}.post-content h6{font-size:1rem;text-transform:uppercase;letter-spacing:.05em}.post-content p{margin-bottom:1.5rem}.post-content a{color:var(--accent-color);text-decoration:none;transition:all .2s ease}.post-content a:hover{opacity:.8}.post-content ul,.post-content ol{margin-bottom:1.5rem;padding-left:2rem}.post-content ul{list-style:disc}.post-content ol{list-style:decimal}.post-content li{margin-bottom:.5rem}.post-content li>ul,.post-content li>ol{margin-top:.5rem;margin-bottom:.5rem}.post-content blockquote{margin:1.5rem 0;padding:1rem 1.5rem;border-left:4px solid var(--accent-color);background:var(--container-bg);border-radius:0 var(--radius)var(--radius)0;font-style:italic;color:var(--text-color)}.post-content blockquote p:last-child{margin-bottom:0}.post-content code{background:rgba(0,0,0,5%);padding:.2em .4em;border-radius:4px;font-family:sfmono-regular,Consolas,liberation mono,Menlo,Courier,monospace;font-size:.85em;color:var(--accent-color)}[data-theme=dark] .post-content code{background:rgba(255,255,255,.1);color:#90cdf4}.post-content pre{background:#1e1e1e;color:#d4d4d4;padding:1.5rem;border-radius:var(--radius);overflow-x:auto;margin:1.5rem 0;font-family:sfmono-regular,Consolas,liberation mono,Menlo,Courier,monospace;font-size:.9rem;line-height:1.5;border:1px solid var(--border-color)}.post-content pre code{background:0 0;padding:0;color:inherit;border-radius:0;font-size:inherit}.post-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.95rem;overflow-x:auto;display:block}@media(min-width:600px){.post-content table{display:table}}.post-content th,.post-content td{padding:.75rem;border:1px solid var(--border-color);text-align:left}.post-content th{background:var(--container-bg);font-weight:600;color:var(--primary-color)}.post-content tr:nth-child(even){background-color:rgba(0,0,0,2%)}[data-theme=dark] .post-content tr:nth-child(even){background-color:rgba(255,255,255,2%)}.post-content img:not(.related-image){max-width:100%;height:auto;border-radius:var(--radius);margin:1.5rem 0;box-shadow:var(--shadow-md);transition:transform .3s ease}.post-content figure.article-image{margin:2rem 0;display:flex;flex-direction:column;align-items:center;width:100%}.post-content figure.article-image img{margin:0;width:100%;height:auto}.post-content figcaption{margin-top:.75rem;font-size:.9rem;color:var(--text-color);opacity:.8;font-style:italic;text-align:center}.zoomable{cursor:zoom-in}.zoomable:hover{transform:scale(1.01)}.post-content hr{border:0;border-top:1px solid var(--border-color);margin:3rem 0;opacity:.5}.post-content strong{color:var(--primary-color);font-weight:700}.post-content ul.task-list{list-style:none;padding-left:0}.post-content .task-list-item input[type=checkbox]{margin-right:.5rem}.code-block-wrapper{margin:1.5rem 0;border-radius:var(--radius);border:1px solid var(--border-color);background:var(--container-bg);overflow:hidden;box-shadow:var(--shadow-md)}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:rgba(0,0,0,3%);border-bottom:1px solid var(--border-color);font-family:var(--font-main);font-size:.85rem}[data-theme=dark] .code-block-header{background:rgba(255,255,255,3%)}.code-lang{font-weight:600;color:var(--text-color);text-transform:uppercase;font-size:.75rem;opacity:.7;letter-spacing:.05em}.copy-code-btn{background:0 0;border:1px solid var(--border-color);color:var(--text-color);padding:.25rem .75rem;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .2s;opacity:.7;font-family:var(--font-main)}.copy-code-btn:hover{opacity:1;background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.code-block-wrapper pre{margin:0 !important;border:none !important;border-radius:0 !important;background:#1e1e1e !important}.mermaid-tabs .code-block-header{justify-content:flex-start;gap:1rem}.mermaid-tab-header{background:0 0;border:none;color:var(--text-color);padding:.25rem 0;font-size:.85rem;cursor:pointer;opacity:.6;border-bottom:2px solid transparent;transition:all .2s;font-family:var(--font-main);font-weight:500}.mermaid-tab-header:hover{opacity:1}.mermaid-tab-header.active{opacity:1;color:var(--accent-color);border-bottom-color:var(--accent-color)}.mermaid-tabs .copy-code-btn{margin-left:auto}.mermaid-tab-content{display:none}.mermaid-tab-content.active{display:block}.mermaid{display:flex;justify-content:center;padding:1.5rem;background:#fff;overflow-x:auto}.contributors-section{margin-top:2rem;display:flex;align-items:center;gap:1rem}.contributors-section h3{font-size:.85rem;margin:0;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);opacity:.7}.contributors-avatars{display:flex;flex-wrap:wrap;gap:0;align-items:center;padding-left:.5rem}.contributor-avatar{display:flex;justify-content:center;align-items:center;width:40px;height:40px;border-radius:50%;overflow:hidden;transition:transform .2s ease;box-shadow:var(--shadow-md);position:relative;color:#fff;font-weight:600;font-size:.75rem;text-transform:uppercase;text-decoration:none;margin-left:-.5rem;border:2px solid var(--bg-color)}.contributor-avatar:hover{transform:translateY(-2px)scale(1.1);z-index:10}.contributor-avatar img{width:100%;height:100%;object-fit:cover;margin:0 !important;display:block;position:absolute;top:0;left:0;z-index:1}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:2rem}.project-card{background:var(--container-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease;position:relative;height:450px}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.featured-badge{position:absolute;top:1rem;left:1rem;background:var(--accent-color);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;z-index:20;box-shadow:0 2px 4px rgba(0,0,0,.2)}.btn-share-icon{position:absolute;top:1rem;right:1rem;z-index:20;width:2.5rem;height:2.5rem;border-radius:50%;background:rgba(0,0,0,.4);color:#fff;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;backdrop-filter:blur(4px)}.btn-share-icon:hover{background:#fff;color:var(--primary-color);transform:scale(1.1)}.project-link{text-decoration:none;display:block;height:100%}.project-media{position:relative;height:100%;overflow:hidden}.project-image{width:100%;height:100%;object-fit:cover;border-bottom:none}.project-overlay{position:absolute;bottom:0;left:0;width:100%;padding:4rem 1.5rem 12rem;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.6) 50%,transparent 100%);color:#fff}.project-overlay h2{color:#fff;font-size:1.5rem;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.project-overlay p{margin:0;font-size:.95rem;color:rgba(255,255,255,.9);text-shadow:0 1px 2px rgba(0,0,0,.3)}.project-actions{padding:1rem 1.5rem;border-top:1px solid var(--border-color);background-color:rgba(0,0,0,2%);display:flex;gap:.75rem;flex-direction:column}.project-card .project-actions{position:absolute;bottom:0;left:0;width:100%;background:0 0;border-top:none;z-index:10;padding-bottom:1.5rem}.project-card .btn-secondary{color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.3)}.project-card .btn-secondary:hover{background-color:rgba(255,255,255,.1);border-color:#fff;color:#fff}.btn{flex:1;display:inline-flex;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:6px;text-decoration:none;transition:all .2s;cursor:pointer}.btn i{margin-right:.5rem}.btn-primary{background-color:var(--primary-color);color:#fff;border:1px solid var(--primary-color)}.btn-primary:hover{background-color:#333;text-decoration:none}.btn-secondary{background-color:transparent;color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--text-color);background-color:#fff;text-decoration:none}@media(min-width:480px){.project-actions{flex-direction:row}.project-overlay{padding-bottom:5rem}}[data-theme=dark] .btn-primary{color:var(--bg-color)}[data-theme=dark] .btn-primary:hover{background-color:#e2e8f0;color:var(--bg-color);border-color:#e2e8f0}.post-card{border-radius:var(--radius);overflow:hidden;position:relative;transition:transform .2s ease,box-shadow .2s ease;height:100%;display:flex;flex-direction:column;background:var(--container-bg);border:1px solid var(--border-color)}.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.post-card.with-image{border:none;min-height:320px;background:#000}.post-card.with-image .post-card-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;opacity:.9}.post-card.with-image:hover .post-card-image{transform:scale(1.05);opacity:.8}.post-card.with-image .post-card-overlay{position:absolute;bottom:0;left:0;width:100%;padding:2rem 1.5rem 1.5rem;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.5) 60%,transparent 100%);z-index:1;display:flex;flex-direction:column;justify-content:flex-end;height:100%;pointer-events:none}.post-card.with-image .post-meta{color:rgba(255,255,255,.9);font-size:.85rem;margin-bottom:.5rem;font-weight:500;margin-top:auto}.post-card.with-image h2{margin:0;font-size:1.5rem;line-height:1.2;pointer-events:auto}.post-card.with-image h2 a{color:#fff;text-decoration:none}.post-card.with-image .post-summary{display:none}.post-card.no-image{padding:2rem;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.post-card.no-image .post-card-content{display:flex;flex-direction:column;height:100%}.post-card.no-image .post-meta{color:var(--text-color);opacity:.6;font-size:.85rem;margin-bottom:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.post-card h2 a::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.post-card.no-image h2{margin:0 0 1rem;font-size:1.5rem;line-height:1.3}.post-card.no-image h2 a{color:var(--primary-color);text-decoration:none;transition:color .2s}.post-card.no-image h2 a:hover{color:var(--accent-color)}.post-card.no-image p{color:var(--text-color);opacity:.8;font-size:1rem;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@media(min-width:768px){.post-card.full-width{grid-column:1/-1}.post-card.full-width.with-image{flex-direction:row;min-height:320px;background:var(--container-bg);border:1px solid var(--border-color)}.post-card.full-width.with-image .post-card-image{position:relative;width:50%;height:auto;min-height:100%;opacity:1}.post-card.full-width.with-image:hover .post-card-image{transform:scale(1.02);opacity:1}.post-card.full-width.with-image .post-card-overlay{position:relative;width:50%;background:0 0;padding:2.5rem;justify-content:center;pointer-events:auto}.post-card.full-width.with-image .post-meta{color:var(--text-color);opacity:.6;margin-top:0;margin-bottom:.5rem}.post-card.full-width.with-image h2{font-size:2rem;margin-bottom:1rem}.post-card.full-width.with-image h2 a{color:var(--primary-color)}.post-card.full-width.with-image h2 a:hover{color:var(--accent-color)}.post-card.full-width.with-image .post-summary{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;color:var(--text-color);opacity:.8;font-size:1rem;line-height:1.6;margin:0}.post-card.full-width.no-image h2{font-size:2rem}.post-card.full-width.no-image p{-webkit-line-clamp:5}}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--primary-color);font-size:.9rem}.form-group input,.form-group textarea{padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--container-bg);color:var(--text-color);font-family:var(--font-main);font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color)}.form-group textarea{min-height:150px;resize:vertical}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color)}.page-link{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:0 .75rem;border-radius:var(--radius);background:var(--container-bg);border:1px solid var(--border-color);color:var(--text-color);font-weight:500;transition:all .2s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.page-link:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color);text-decoration:none}.page-link.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.page-link.disabled{opacity:.5;pointer-events:none;cursor:default}[data-theme=dark] .page-link.active{color:var(--bg-color)}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);z-index:10000;display:flex;justify-content:center;align-items:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.lightbox-overlay.active{opacity:1;visibility:visible}.lightbox-image{max-width:90%;max-height:90vh;object-fit:contain;transform:scale(.9);transition:transform .3s ease;border-radius:4px;box-shadow:0 5px 15px rgba(0,0,0,.5)}.lightbox-overlay.active .lightbox-image{transform:scale(1)}.lightbox-close{position:absolute;top:20px;right:30px;background:0 0;border:none;color:#fff;font-size:2rem;cursor:pointer;z-index:10001;padding:10px;transition:color .2s}.lightbox-close:hover{color:var(--accent-color)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:0 0;border:none;color:rgba(255,255,255,.7);font-size:3rem;cursor:pointer;z-index:10001;padding:20px;transition:color .2s,transform .2s;user-select:none}.lightbox-nav:hover{color:#fff;transform:translateY(-50%)scale(1.1)}.lightbox-prev{left:10px}.lightbox-next{right:10px}.toast-container{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%);z-index:10000;display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none;width:100%;max-width:400px}.toast{position:relative;background:rgba(30,30,30,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:none;color:#fff;padding:.6rem 1.25rem;border-radius:50px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.75rem;transform:translateY(20px);opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.85rem;pointer-events:auto;width:fit-content}.toast.show{transform:translateY(0);opacity:1;visibility:visible}.toast.success{background:rgba(30,30,30,.9);color:#fff}.toast.error{background:#c53030;color:#fff}.cookie-consent-banner{position:fixed;bottom:0;left:0;width:100%;background:var(--bg-color);border-top:1px solid var(--border-color);padding:1rem;z-index:10000;transform:translateY(100%);transition:transform .3s ease-in-out;box-shadow:0 -4px 6px rgba(0,0,0,5%)}.cookie-consent-banner.visible{transform:translateY(0)}.cookie-content{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.cookie-content p{margin:0;font-size:.9rem;color:var(--text-color)}.cookie-actions{display:flex;gap:.5rem}.cookie-actions button{padding:.5rem 1rem;border-radius:var(--radius);font-size:.85rem;cursor:pointer;transition:all .2s;font-weight:500}.accept-cookies{background:var(--primary-color);color:var(--bg-color);border:1px solid var(--primary-color)}.accept-cookies:hover{opacity:.9}.decline-cookies{background:0 0;border:1px solid var(--border-color);color:var(--text-color)}.decline-cookies:hover{border-color:var(--text-color)}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;background:var(--primary-color);color:var(--bg-color);width:3rem;height:3rem;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s ease;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.1)}.scroll-to-top.visible{opacity:1;visibility:visible}.scroll-to-top:hover{transform:translateY(-3px);box-shadow:0 5px 15px rgba(0,0,0,.2)}.project-card{position:relative}.rating-badge{display:inline-block;margin-bottom:.5rem;background:rgba(255,255,255,.75);color:#c53030;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:700;box-shadow:0 4px 6px rgba(0,0,0,5%);border:1px solid rgba(255,255,255,.3);z-index:2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative;cursor:help}.rating-badge[data-tooltip]::before{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);margin-bottom:8px;padding:.5rem .75rem;background:rgba(0,0,0,.85);color:#fff;font-size:.7rem;border-radius:4px;white-space:normal;max-width:200px;width:max-content;text-align:center;z-index:10;pointer-events:none;font-weight:500;opacity:0;visibility:hidden;transition:none}.rating-badge[data-tooltip]::after{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);margin-bottom:3px;border:5px solid transparent;border-top-color:rgba(0,0,0,.85);z-index:10;pointer-events:none;opacity:0;visibility:hidden;transition:none}.rating-badge[data-tooltip]:hover::before,.rating-badge[data-tooltip]:hover::after{opacity:1;visibility:visible}[data-theme=dark] .rating-badge{background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.1);color:#feb2b2;text-shadow:0 1px 2px rgba(0,0,0,.5)}