.port-label{font-family:var(--fd);font-size:1.6rem;margin:4rem 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:.8rem}
.port-label .dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.port-label .dot.g{background:var(--ac)}.port-label .dot.c{background:var(--co)}.port-label .dot.t{background:var(--tl)}
.csg{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.csc{background:var(--bg3);border:1px solid var(--bd);border-radius:var(--r);padding:2rem;transition:all .45s var(--e);position:relative;color:var(--tx);display:block;overflow:hidden}
.csc:hover{border-color:var(--acm);transform:translateY(-5px);box-shadow:0 20px 55px rgba(0,0,0,.35)}
.csc::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--acd),transparent);opacity:0;transition:opacity .4s}.csc:hover::before{opacity:1}
.csc-arrow{position:absolute;top:1.5rem;right:1.5rem;width:34px;height:34px;background:var(--ac);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-6px,6px);transition:all .4s var(--e);z-index:3}
.csc:hover .csc-arrow{opacity:1;transform:none}.csc-arrow svg{width:14px;height:14px;stroke:var(--bg);stroke-width:2.5}
.csn{font-family:var(--fm);font-size:.58rem;color:var(--tx3);letter-spacing:.18em;margin-bottom:.5rem;position:relative;z-index:1}
.csc h3{font-family:var(--fd);font-size:1.35rem;margin-bottom:.5rem;line-height:1.2;position:relative;z-index:1}
.csc p{font-size:.82rem;color:var(--tx2);line-height:1.6;margin-bottom:1.2rem;font-weight:300;position:relative;z-index:1}
.csr{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;padding-top:1rem;border-top:1px solid var(--bd);position:relative;z-index:1}
.csr.cols-4{grid-template-columns:repeat(4,1fr)}
.csri{text-align:center}
.csrn{font-family:var(--fd);font-size:1.1rem;font-weight:700}
.csrn.g{color:var(--ac)}.csrn.t{color:var(--tl)}.csrn.c{color:var(--co)}.csrn.v{color:var(--vi)}
.csrl{font-size:.52rem;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em;font-weight:500}
.csc-img{width:calc(100% + 4rem);margin:-2rem -2rem 1.5rem;height:180px;overflow:hidden;position:relative}
.csc-img svg{width:100%;height:100%}.csc-img img{width:100%;height:100%;object-fit:cover;display:block}.csc-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg3),transparent 60%)}
@media(max-width:1024px){.csg{grid-template-columns:1fr}}

/* ─── Previous Projects Popup ─── */
.pm-overlay{position:fixed;inset:0;background:rgba(4,4,10,.88);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s ease}
.pm-overlay.open{opacity:1;pointer-events:all}
.pm-box{background:var(--bg3);border:1px solid var(--bd);border-radius:16px;width:min(860px,100%);max-height:92vh;overflow-y:auto;position:relative;transform:translateY(24px) scale(.96);transition:transform .38s var(--e);scrollbar-width:thin;scrollbar-color:var(--bd) transparent}
.pm-overlay.open .pm-box{transform:none}
.pm-close{position:absolute;top:1rem;right:1rem;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:var(--tx);font-size:1.35rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s,transform .25s,border-color .2s;padding:0}
.pm-close:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);transform:rotate(90deg)}
.pm-img-wrap{width:100%;height:340px;overflow:hidden;border-radius:16px 16px 0 0;position:relative}
.pm-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--e)}
.pm-overlay.open .pm-img-wrap img{transform:scale(1.02)}
.pm-img-badge{position:absolute;bottom:1rem;left:1.5rem;background:rgba(4,4,10,.75);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:.35rem .75rem;font-family:var(--fm);font-size:.55rem;color:var(--tx3);letter-spacing:.18em}
.pm-body{padding:1.75rem 2rem 2rem}
.pm-title{font-family:var(--fd);font-size:1.55rem;margin:0 0 .75rem;line-height:1.25;padding-right:2.5rem}
.pm-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.1rem}
.pm-desc{font-size:.86rem;color:var(--tx2);line-height:1.75;font-weight:300;margin:0 0 1.5rem}
.pm-meta{display:flex;gap:2.5rem;padding-top:1.2rem;border-top:1px solid var(--bd)}
.pm-mi{display:flex;flex-direction:column;gap:.3rem}
.pm-ml{font-size:.5rem;color:var(--tx3);text-transform:uppercase;letter-spacing:.1em;font-weight:500}
.pm-mv{font-family:var(--fd);font-size:1.05rem;font-weight:700;color:var(--tl)}
@media(max-width:600px){.pm-img-wrap{height:220px}.pm-body{padding:1.25rem 1.25rem 1.5rem}.pm-title{font-size:1.2rem}.pm-meta{gap:1.5rem}}
