.read-progress-bar{background:var(--brand-accent);z-index:9999;border-radius:0 var(--radius-full)var(--radius-full)0;height:3px;transition:width .1s linear;position:fixed;top:0;left:0}.article-page{background:var(--bg-main);min-height:100svh;padding-top:68px}.article-loading{min-height:60vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:.9rem;display:flex}.article-loading svg{color:var(--brand-accent);font-size:2rem}.article-not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:60vh;padding:2rem;display:flex}.article-not-found svg{color:var(--brand-accent);opacity:.6;margin-bottom:.5rem;font-size:3rem}.article-not-found h1{font-family:var(--font-display);letter-spacing:.02em;color:var(--brand-black);font-size:2.5rem}.article-not-found p{color:var(--text-secondary);margin-bottom:1rem}.article-back-nav{background:var(--bg-surface);border-bottom:1px solid var(--border-light);padding:0 2rem}.article-back-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1100px;height:56px;margin:0 auto;display:flex}.article-back-btn{font-size:.82rem;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);align-items:center;gap:.5rem;text-decoration:none;transition:color .2s,gap .2s;display:inline-flex}.article-back-btn:hover{color:var(--brand-accent);gap:.75rem}.article-back-actions{align-items:center;gap:.75rem;display:flex}.article-action-btn{border-radius:var(--radius-full);font-family:var(--font-body);font-size:.78rem;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border:1.5px solid var(--border-light);background:var(--bg-surface);color:var(--text-primary);align-items:center;gap:.4rem;padding:.5rem 1rem;text-decoration:none;transition:all .22s;display:inline-flex}.article-action-btn:hover{border-color:var(--brand-black);color:var(--brand-black)}.article-action-hire{background:var(--brand-black);border-color:var(--brand-black);color:#fff}.article-action-hire:hover{background:var(--brand-accent);border-color:var(--brand-accent);color:#fff;transform:translateY(-2px)}.share-menu{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);width:200px;box-shadow:var(--shadow-strong);z-index:500;padding:.4rem;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.share-item{width:100%;font-family:var(--font-body);font-size:.85rem;font-weight:var(--fw-medium);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.65rem;padding:.65rem .875rem;text-decoration:none;transition:background .18s,color .18s;display:flex}.share-item:hover{background:var(--bg-main);color:var(--brand-accent)}.share-item svg{width:14px;color:var(--text-secondary);flex-shrink:0;transition:color .18s}.share-item:hover svg{color:var(--brand-accent)}.article-hero{max-width:760px;margin:0 auto;padding:4rem 2rem 2.5rem}.article-hero-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.article-hero-tag{font-size:.68rem;font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--brand-accent);border-radius:var(--radius-full);background:#ff3b3014;align-items:center;gap:.3rem;padding:.25rem .7rem;display:inline-flex}.article-title{font-family:var(--font-display);letter-spacing:.02em;color:var(--brand-black);margin-bottom:1.25rem;font-size:clamp(2.2rem,5vw,4rem);line-height:1}.article-excerpt{color:var(--text-secondary);margin-bottom:2rem;font-size:1.125rem;line-height:1.75}.article-hero-meta{border-top:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding-top:1.5rem;display:flex}.article-author{align-items:center;gap:.875rem;display:flex}.article-author-avatar{object-fit:cover;border:2px solid var(--border-light);border-radius:50%;flex-shrink:0;width:44px;height:44px}.article-author-initials{background:linear-gradient(135deg,var(--brand-black),#333);color:#fff;width:44px;height:44px;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.article-author-name{font-size:.875rem;font-weight:var(--fw-bold);color:var(--text-primary);align-items:center;gap:.35rem;margin-bottom:.15rem;display:flex}.article-author-name svg{color:var(--brand-accent);font-size:.7rem}.article-author-date{color:var(--text-secondary);font-size:.75rem}.article-hero-stats{color:var(--text-secondary);align-items:center;gap:1rem;font-size:.8rem;display:flex}.article-hero-stats span{align-items:center;gap:.35rem;display:flex}.article-hero-stats svg{color:var(--brand-accent);font-size:.75rem}.article-featured-img-wrap{max-width:900px;margin:0 auto 3rem;padding:0 2rem}.article-featured-img{object-fit:cover;border-radius:var(--radius-lg);width:100%;height:auto;max-height:500px;box-shadow:var(--shadow-strong);display:block}.article-body{grid-template-columns:1fr 300px;align-items:start;gap:4rem;max-width:1100px;margin:0 auto;padding:0 2rem 4rem;display:grid}.article-content{min-width:0}.article-paragraph{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.0625rem;line-height:1.85}.article-heading{font-family:var(--font-display);letter-spacing:.02em;color:var(--brand-black);margin-top:2.5rem;margin-bottom:1rem;line-height:1}.article-h1{font-size:3rem}.article-h2{font-size:2.2rem}.article-h3{font-size:1.7rem}.article-h4{font-size:1.3rem}.article-h5{font-size:1.1rem;font-family:var(--font-body);font-weight:var(--fw-bold)}.article-h6{font-size:.95rem;font-family:var(--font-body);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.article-figure{margin:2rem 0}.article-img{border-radius:var(--radius-md);width:100%;height:auto;box-shadow:var(--shadow-soft);display:block}.article-figcaption{text-align:center;color:var(--text-secondary);margin-top:.75rem;font-size:.8rem;font-style:italic}.article-code-wrap{border-radius:var(--radius-md);background:#0d0d0d;border:1px solid #1e1e1e;margin:2rem 0;overflow:hidden}.article-code-header{background:#161616;border-bottom:1px solid #1e1e1e;justify-content:space-between;align-items:center;padding:.55rem 1rem;display:flex}.article-code-dots{align-items:center;gap:.4rem;display:flex}.article-code-dots span{border-radius:50%;width:10px;height:10px;display:block}.article-code-dots span:first-child{background:#ff5f57}.article-code-dots span:nth-child(2){background:#febc2e}.article-code-dots span:nth-child(3){background:#28c840}.article-pre{color:#e2e8f0;background:0 0;margin:0;padding:1.25rem 1.5rem;font-size:.875rem;line-height:1.75;overflow-x:auto}.article-pre code{font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:inherit;color:inherit;background:0 0;padding:0}.code-copy-btn{border-radius:var(--radius-full);color:#9ca3af;font-family:var(--font-body);font-size:.7rem;font-weight:var(--fw-medium);cursor:pointer;letter-spacing:.04em;background:#1e1e1e;border:1px solid #2a2a2a;align-items:center;gap:.35rem;padding:.28rem .7rem;transition:all .2s;display:inline-flex}.code-copy-btn:hover{color:#e2e8f0;background:#2a2a2a;border-color:#3a3a3a}.code-copy-btn.copied{color:#22c55e;background:#22c55e1f;border-color:#22c55e4d}.article-empty{color:var(--text-secondary);text-align:center;padding:3rem 0;font-size:.9rem}.article-delimiter{border:none;border-top:1px solid var(--border-light);margin:2.5rem 0}.article-warning{border-radius:0 var(--radius-md)var(--radius-md)0;background:#eab30814;border:1px solid #eab30840;border-left:4px solid #eab308;flex-direction:column;gap:.4rem;margin:2rem 0;padding:1.25rem 1.5rem;display:flex}.article-warning strong{font-size:.875rem;font-weight:var(--fw-bold);color:#b45309;text-transform:uppercase;letter-spacing:.06em}.article-warning p{color:var(--text-primary);margin:0;font-size:.9375rem;line-height:1.65}.article-table-wrap{border-radius:var(--radius-md);border:1px solid var(--border-light);margin:2rem 0;overflow-x:auto}.article-table{border-collapse:collapse;width:100%;font-size:.9rem}.article-table th{background:var(--bg-dark);color:var(--text-inverse);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;text-align:left;padding:.75rem 1rem;font-size:.8rem}.article-table td{border-top:1px solid var(--border-light);color:var(--text-primary);padding:.75rem 1rem;line-height:1.6}.article-table tr:nth-child(2n) td{background:var(--bg-main)}.article-checklist{flex-direction:column;gap:.6rem;margin:1.5rem 0;padding:0;list-style:none;display:flex}.article-checklist li{color:var(--text-primary);align-items:flex-start;gap:.75rem;font-size:1.0625rem;line-height:1.65;display:flex}.article-checklist li.checked{color:var(--text-secondary);-webkit-text-decoration:line-through #0003;text-decoration:line-through #0003}.article-checklist-box{border:2px solid var(--border-light);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:2px;font-size:.7rem;transition:all .2s;display:flex}.article-checklist li.checked .article-checklist-box{color:#fff;background:#22c55e;border-color:#22c55e}.article-raw{margin:1.5rem 0}.article-blockquote{border-left:4px solid var(--brand-accent);border-radius:0 var(--radius-md)var(--radius-md)0;background:#ff3b300a;margin:2rem 0;padding:1.5rem 2rem}.article-blockquote p{color:var(--text-primary);margin-bottom:.5rem;font-size:1.125rem;font-style:italic;line-height:1.7}.article-cite{color:var(--brand-accent);font-size:.82rem;font-weight:var(--fw-medium);font-style:normal}.article-list{margin:1.5rem 0;padding-left:1.75rem}.article-list li{color:var(--text-primary);margin-bottom:.4rem;font-size:1.0625rem;line-height:1.8}.article-ul li::marker{color:var(--brand-accent)}.article-ol li::marker{color:var(--brand-accent);font-weight:var(--fw-bold)}.article-embed{border-radius:var(--radius-md);height:0;margin:2rem 0;padding-bottom:56.25%;position:relative;overflow:hidden}.article-embed iframe{border:none;width:100%;height:100%;position:absolute;inset:0}.article-embed-link{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--brand-accent);word-break:break-all;padding:1rem;font-size:.875rem;text-decoration:none;transition:background .2s;display:block}.article-embed-link:hover{background:var(--bg-main)}.article-sidebar{flex-direction:column;gap:1.25rem;display:flex;position:sticky;top:90px}.sidebar-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:1.5rem}.sidebar-card-title{font-family:var(--font-display);letter-spacing:.06em;color:var(--brand-black);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1rem;display:flex}.sidebar-card-title svg{color:var(--brand-accent);font-size:.8rem}.sidebar-author-avatar{border:3px solid var(--border-light);border-radius:50%;width:64px;height:64px;margin:0 auto 1rem;overflow:hidden}.sidebar-author-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-author-initials{background:linear-gradient(135deg,var(--brand-black),#333);color:#fff;width:100%;height:100%;font-family:var(--font-display);justify-content:center;align-items:center;font-size:1.3rem;display:flex}.sidebar-author-name{font-family:var(--font-display);letter-spacing:.04em;text-align:center;color:var(--brand-black);margin-bottom:.5rem;font-size:1.3rem}.sidebar-author-bio{color:var(--text-secondary);text-align:center;margin-bottom:1.25rem;font-size:.8125rem;line-height:1.6}.sidebar-tags{flex-wrap:wrap;gap:.5rem;display:flex}.sidebar-tag{font-size:.68rem;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-full);cursor:default;padding:.25rem .65rem;transition:background .18s,color .18s,border-color .18s}.sidebar-tag:hover{color:var(--brand-accent);background:#ff3b3014;border-color:#ff3b3040}.sidebar-share-btns{flex-direction:column;gap:.5rem;display:flex}.sidebar-share-btn{border-radius:var(--radius-md);font-size:.82rem;font-weight:var(--fw-medium);border:1px solid var(--border-light);color:var(--text-primary);background:var(--bg-main);align-items:center;gap:.65rem;padding:.6rem .875rem;text-decoration:none;transition:all .2s;display:flex}.sidebar-share-btn:hover{transform:translate(4px)}.sidebar-share-x:hover{color:#fff;background:#000;border-color:#000}.sidebar-share-li:hover{color:#fff;background:#0077b5;border-color:#0077b5}.sidebar-share-wa:hover{color:#fff;background:#25d366;border-color:#25d366}.article-footer-strip{border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);background:var(--bg-surface);padding:1.25rem 2rem}.article-footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;max-width:1100px;margin:0 auto;display:flex}.article-footer-tags{flex-wrap:wrap;gap:.5rem;display:flex}.article-footer-actions{align-items:center;gap:.75rem;display:flex}.related-section{background:var(--bg-main);padding:5rem 2rem}.related-inner{max-width:1100px;margin:0 auto}.related-heading{font-family:var(--font-display);letter-spacing:.02em;color:var(--brand-black);margin-bottom:2.5rem;font-size:clamp(2rem,4vw,3.5rem);line-height:.95}.related-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.related-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);flex-direction:column;text-decoration:none;transition:transform .3s,box-shadow .3s;display:flex;overflow:hidden}.related-card:hover{box-shadow:var(--shadow-strong);transform:translateY(-5px)}.related-card-img{background:linear-gradient(135deg,#1c1c1e,#2c2c2e);flex-shrink:0;height:160px;position:relative;overflow:hidden}.related-card-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.related-card:hover .related-card-img img{transform:scale(1.06)}.related-card-placeholder{width:100%;height:100%;font-family:var(--font-display);color:#ffffff0f;justify-content:center;align-items:center;font-size:3.5rem;display:flex}.related-card-badge{background:var(--brand-accent);color:#fff;font-size:.6rem;font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius-full);padding:.2rem .55rem;position:absolute;top:.75rem;left:.75rem}.related-card-body{flex-direction:column;flex:1;padding:1.25rem;display:flex}.related-card-meta{color:var(--text-secondary);align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.7rem;display:flex}.related-dot{background:var(--border-light);border-radius:50%;width:3px;height:3px}.related-card-title{font-family:var(--font-display);letter-spacing:.02em;color:var(--text-primary);margin-bottom:.5rem;font-size:1.15rem;line-height:1.2;transition:color .2s}.related-card:hover .related-card-title{color:var(--brand-accent)}.related-card-excerpt{color:var(--text-secondary);-webkit-box-orient:vertical;flex:1;margin-bottom:1rem;font-size:.8rem;line-height:1.6;display:-webkit-box;overflow:hidden}.related-read-more{font-size:.75rem;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.08em;color:var(--brand-accent);align-items:center;gap:.35rem;transition:gap .2s;display:inline-flex}.related-card:hover .related-read-more{gap:.6rem}.hire-banner{background:var(--bg-dark);padding:5rem 2rem}.hire-banner-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;max-width:1100px;margin:0 auto;display:flex}.hire-banner-text h2{font-family:var(--font-display);letter-spacing:.02em;color:var(--text-inverse);margin-bottom:.5rem;font-size:clamp(2rem,4vw,3.5rem);line-height:.95}.hire-banner-text p{color:#ffffff8c;font-size:1rem}.hire-banner-actions{flex-shrink:0;align-items:center;gap:1rem;display:flex}.hire-banner .btn-secondary{color:#ffffffb3;border-color:#fff3}.hire-banner .btn-secondary:hover{color:#fff;border-color:#fff}.scroll-top-btn{background:var(--brand-black);color:#fff;cursor:pointer;width:44px;height:44px;box-shadow:var(--shadow-strong);z-index:500;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;transition:background .2s,transform .2s;display:flex;position:fixed;bottom:2rem;right:2rem}.scroll-top-btn:hover{background:var(--brand-accent);transform:translateY(-3px)}@media (max-width:960px){.article-body{grid-template-columns:1fr;gap:3rem}.article-sidebar{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid;position:static}.related-grid{grid-template-columns:repeat(2,1fr)}.hire-banner-inner{text-align:center;flex-direction:column}.hire-banner-actions{justify-content:center}}@media (max-width:640px){.article-hero{padding:2.5rem 1.25rem 2rem}.article-featured-img-wrap{padding:0 1.25rem}.article-body{padding:0 1.25rem 3rem}.article-sidebar{grid-template-columns:1fr}.article-hero-meta{flex-direction:column;align-items:flex-start;gap:.75rem}.article-back-inner{flex-wrap:wrap;height:auto;padding:.75rem 0}.article-title{font-size:clamp(1.8rem,7vw,2.5rem)}.related-grid{grid-template-columns:1fr}.article-footer-inner{flex-direction:column;align-items:flex-start}.scroll-top-btn{width:40px;height:40px;bottom:1.25rem;right:1.25rem}.share-menu{left:0;right:auto}}.projects-page{background:var(--bg-main);min-height:100svh;padding-top:68px}.projects-hero{max-width:1100px;margin:0 auto;padding:5rem 2rem 3rem}.projects-hero-title{font-family:var(--font-display);letter-spacing:.02em;color:var(--brand-black);margin-bottom:1.25rem;font-size:clamp(4rem,9vw,8rem);line-height:.92}.projects-hero-title .accent{color:var(--brand-accent)}.projects-hero-sub{color:var(--text-secondary);max-width:520px;font-size:1.0625rem;line-height:1.75}.projects-filters-wrap{border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);background:var(--bg-surface);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:1rem 2rem;position:sticky;top:68px}.projects-filters-inner{flex-wrap:wrap;align-items:center;gap:1rem;max-width:1100px;margin:0 auto;display:flex}.projects-tech-pills{flex-wrap:wrap;flex:1;gap:.4rem;display:flex}.projects-tech-pill{border-radius:var(--radius-full);border:1.5px solid var(--border-light);font-family:var(--font-body);font-size:.75rem;font-weight:var(--fw-medium);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;padding:.3rem .85rem;transition:all .2s}.projects-tech-pill.active{background:var(--brand-black);color:#fff;border-color:var(--brand-black)}.projects-tech-pill:hover:not(.active){border-color:var(--brand-accent);color:var(--brand-accent)}.projects-grid-wrap{padding:3rem 2rem 6rem}.projects-grid-inner{max-width:1100px;margin:0 auto}.projects-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.projects-state{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:5rem 2rem;font-size:.9rem;display:flex}.projects-state-icon{color:var(--border-light);font-size:2.5rem}.project-listing-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);flex-direction:column;text-decoration:none;transition:transform .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden}.project-listing-card:before{content:"";background:var(--brand-accent);z-index:1;width:0;height:3px;transition:width .4s;position:absolute;top:0;left:0}.project-listing-card:hover{box-shadow:var(--shadow-strong);transform:translateY(-6px)}.project-listing-card:hover:before{width:100%}.plc-img{background:linear-gradient(135deg,#1c1c1e,#2c2c2e);flex-shrink:0;height:220px;position:relative;overflow:hidden}.plc-img img{object-fit:cover;width:100%;height:100%;transition:transform .5s cubic-bezier(.16,1,.3,1);display:block}.project-listing-card:hover .plc-img img{transform:scale(1.06)}.plc-img-placeholder{color:#ffffff0f;justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.plc-img-overlay{background:linear-gradient(#0000 40%,#0006 100%);position:absolute;inset:0}.plc-number{font-family:var(--font-display);color:#ffffff1f;letter-spacing:.02em;font-size:3rem;line-height:1;position:absolute;bottom:1rem;left:1.25rem}.plc-body{flex-direction:column;flex:1;padding:1.5rem;display:flex}.plc-title{font-family:var(--font-display);letter-spacing:.03em;color:var(--text-primary);margin-bottom:.6rem;font-size:1.6rem;line-height:1.1;transition:color .2s}.project-listing-card:hover .plc-title{color:var(--brand-accent)}.plc-desc{color:var(--text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin-bottom:1.25rem;font-size:.875rem;line-height:1.65;display:-webkit-box;overflow:hidden}.plc-techs{flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem;display:flex}.plc-tech{background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:.68rem;font-weight:var(--fw-medium);letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);padding:.18rem .6rem}.plc-tech-more{color:var(--brand-accent);background:#ff3b300d;border-color:#ff3b3033}.plc-footer{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.plc-links{gap:.5rem;display:flex}.plc-link-badge{font-size:.68rem;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.07em;border-radius:var(--radius-full);color:var(--brand-accent);background:#ff3b3012;border:1px solid #ff3b302e;align-items:center;gap:.3rem;padding:.2rem .6rem;display:inline-flex}.plc-cta{font-size:.78rem;font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);align-items:center;gap:.35rem;transition:color .2s,gap .2s;display:inline-flex}.project-listing-card:hover .plc-cta{color:var(--brand-accent);gap:.6rem}.proj-gallery{border-radius:var(--radius-md);grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:2.5rem;display:grid;overflow:hidden}.proj-gallery-item{cursor:zoom-in;border-radius:var(--radius-sm);background:var(--bg-dark);height:200px;position:relative;overflow:hidden}.proj-gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.proj-gallery-item:hover img{transform:scale(1.05)}.proj-gallery-overlay{opacity:0;font-size:.8rem;font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.1em;color:#fff;background:#00000073;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:absolute;inset:0}.proj-gallery-item:hover .proj-gallery-overlay{opacity:1}.proj-lightbox{z-index:1000;cursor:zoom-out;background:#000000eb;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.proj-lightbox img{border-radius:var(--radius-md);max-width:100%;max-height:90vh;box-shadow:var(--shadow-strong);cursor:default}.proj-lightbox-close{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;transition:background .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.proj-lightbox-close:hover{background:var(--brand-accent);border-color:var(--brand-accent)}.proj-info-list{flex-direction:column;gap:.6rem;display:flex}.proj-info-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding-bottom:.6rem;font-size:.8125rem;display:flex}.proj-info-row:last-child{border-bottom:none;padding-bottom:0}.proj-info-label{color:var(--text-secondary);font-weight:var(--fw-medium)}.proj-info-value{color:var(--text-primary)}.proj-info-link{color:var(--brand-accent);font-weight:var(--fw-medium);align-items:center;gap:.3rem;font-size:.8125rem;text-decoration:none;transition:gap .2s;display:inline-flex}.proj-info-link:hover{gap:.5rem}.proj-cta-card{text-align:center}.proj-cta-text{color:var(--text-secondary);margin-bottom:1rem;font-size:.875rem;line-height:1.5}@media (max-width:960px){.projects-grid{grid-template-columns:1fr}.proj-gallery{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.projects-hero{padding:3rem 1.25rem 2rem}.projects-filters-wrap{padding:.75rem 1.25rem}.projects-grid-wrap{padding:2rem 1.25rem 4rem}.proj-gallery{grid-template-columns:1fr}.plc-img{height:180px}}
