a.logo{text-decoration:none;color:var(--text-light)}.nav-active{color:var(--primary)!important}.nav-projects-active{border-color:var(--primary)!important;color:var(--primary)!important;background:#1d6ef114!important}.proj-page-hero{padding:160px 0 5rem;position:relative;overflow:hidden}.proj-page-hero:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:var(--primary-glow);filter:blur(140px);z-index:-1;opacity:.15}.proj-page-label{display:block;font-size:.75rem;font-weight:800;letter-spacing:2px;color:var(--primary);text-transform:uppercase;margin-bottom:1.5rem}.proj-page-title{font-size:clamp(3.5rem,9vw,7rem);font-weight:900;font-family:var(--font-heading);letter-spacing:-.04em;line-height:.9;margin-bottom:1.5rem}.proj-page-sub{color:var(--text-gray);font-size:1.1rem;opacity:.7}.proj-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.proj-card{display:grid;grid-template-columns:380px 1fr;border:1px solid var(--border-light);background:#ffffff03;cursor:pointer;transition:var(--transition);overflow:hidden;opacity:0;transform:translateY(30px)}.proj-card.reveal-in{opacity:1;transform:translateY(0);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1),border-color .4s,background .4s}.proj-card:hover{border-color:var(--primary);background:#ffffff08;transform:translateY(-4px)}.proj-thumb{position:relative;overflow:hidden;background:var(--bg-alt);min-height:200px}.proj-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.16,1,.3,1)}.proj-card:hover .proj-thumb img{transform:scale(1.04)}.proj-thumb-placeholder{width:100%;height:100%;min-height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f14,#1a1a22);position:relative;overflow:hidden}.proj-thumb-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.04) 1px,transparent 0);background-size:28px 28px}.thumb-initials{font-size:3.5rem;font-weight:900;font-family:var(--font-heading);color:#ffffff12;letter-spacing:-.05em;position:relative;z-index:1}.proj-card-content{padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between;gap:1.5rem}.proj-card-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.proj-card-badge{display:inline-block;font-size:.65rem;font-weight:800;letter-spacing:2px;color:var(--accent);background:#10b9811a;border:1px solid rgba(16,185,129,.25);padding:.3rem .9rem;border-radius:50px;text-transform:uppercase}.proj-badge-freelance{color:#fc5757!important;background:#fc57571a!important;border-color:#fc57574d!important}.proj-badge-poc{color:#38bdf8!important;background:#38bdf81a!important;border-color:#38bdf84d!important}.proj-badge-training{color:#a78bfa!important;background:#a78bfa1a!important;border-color:#a78bfa4d!important}.proj-card-title{font-size:1.9rem;font-weight:800;font-family:var(--font-heading);letter-spacing:-.03em;margin-bottom:.75rem;line-height:1.1}.proj-card-desc{color:var(--text-gray);line-height:1.7;font-size:.93rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.proj-card-tags{display:flex;flex-wrap:wrap;gap:.4rem}.proj-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:4vh 3vw}.proj-modal.active{display:flex}.proj-modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#050505e0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer}.proj-modal-inner{position:relative;z-index:1;width:100%;max-width:1400px;height:100%;display:flex;border:1px solid var(--border-light);box-shadow:0 40px 100px #000c;opacity:0;transform:scale(.96) translateY(16px);transition:opacity .4s cubic-bezier(.16,1,.3,1),transform .4s cubic-bezier(.16,1,.3,1)}.proj-modal.active .proj-modal-inner{opacity:1;transform:scale(1) translateY(0)}.proj-iframe-pane{flex:6;position:relative;background:#e8e8e8;border-right:1px solid var(--border-light)}#proj-iframe{width:100%;height:100%;border:none;display:block}.iframe-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);transition:opacity .4s ease;pointer-events:none}.iframe-loading.hidden{opacity:0}.iframe-spinner{width:36px;height:36px;border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.proj-details-pane{width:460px;flex-shrink:0;background:var(--bg-dark);display:flex;flex-direction:column;overflow:hidden;border-left:1px solid var(--border-light)}.proj-details-header{padding:2rem 2rem 1.5rem;border-bottom:1px solid var(--border-light);flex-shrink:0}.proj-details-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.proj-details-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.6rem}.proj-details-badge{display:inline-block;font-size:.65rem;font-weight:800;letter-spacing:2px;color:var(--accent);background:#10b9811a;border:1px solid rgba(16,185,129,.25);padding:.3rem .8rem;border-radius:50px;text-transform:uppercase}.proj-details-name{font-size:1.9rem;font-weight:800;font-family:var(--font-heading);letter-spacing:-.03em;line-height:1.05}.proj-modal-close-btn{background:none;border:1px solid var(--border-light);color:var(--text-gray);font-size:1.2rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:var(--transition);line-height:1;padding:0;margin-top:4px}.proj-modal-close-btn:hover{border-color:var(--primary);color:var(--text-light);transform:rotate(90deg)}.proj-details-ext-link{font-size:.78rem;font-weight:600;color:var(--text-gray);text-decoration:none;letter-spacing:.3px;transition:color .3s}.proj-details-ext-link:hover{color:var(--primary)}.proj-details-body{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:2rem;scrollbar-width:thin;scrollbar-color:var(--border-light) transparent}.proj-details-desc{color:var(--text-gray);line-height:1.75;font-size:.93rem}.proj-details-desc p+p{margin-top:.9rem}.proj-details-tags-block{border:1px solid var(--border-light);padding:1.5rem}.proj-section-label{display:block;font-size:.68rem;font-weight:800;color:var(--primary);letter-spacing:2px;text-transform:uppercase;margin-bottom:1rem}.proj-details-tags{display:flex;flex-wrap:wrap;gap:.45rem}.proj-gallery-block{margin-top:auto}.proj-gallery-container{display:flex;align-items:center;gap:.6rem;margin-top:1rem}.gallery-nav-btn{background:none;border:1px solid var(--border-light);color:var(--text-gray);width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.3rem;flex-shrink:0;transition:var(--transition);padding:0;line-height:1}.gallery-nav-btn:hover:not(:disabled){border-color:var(--primary);color:var(--text-light)}.gallery-nav-btn:disabled{opacity:.25;cursor:default}.proj-gallery-track-wrapper{flex:1;overflow:hidden}.proj-gallery-track{display:flex;gap:6px;transition:transform .4s cubic-bezier(.16,1,.3,1)}.gallery-thumb{flex-shrink:0;height:108px;width:auto;object-fit:cover;border:1px solid var(--border-light);cursor:zoom-in;transition:var(--transition);display:block;background:var(--bg-alt)}.gallery-thumb:hover{border-color:var(--primary);transform:scale(1.04)}.img-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:none;align-items:center;justify-content:center;padding:2rem}.img-lightbox.active{display:flex}.lightbox-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer}#lightbox-img{position:relative;max-width:90vw;max-height:90vh;object-fit:contain;border:1px solid var(--border-light);z-index:1;animation:lb-in .3s cubic-bezier(.16,1,.3,1)}@keyframes lb-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.lightbox-close{position:absolute;top:1.5rem;right:2rem;background:none;border:none;color:#fff9;font-size:2.5rem;cursor:pointer;z-index:2;line-height:1;transition:color .3s,transform .3s;padding:0}.lightbox-close:hover{color:#fff;transform:rotate(90deg)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff12;border:1px solid rgba(255,255,255,.15);color:#ffffffb3;font-size:2.4rem;width:52px;height:52px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;line-height:1;padding:0;transition:background .2s,color .2s,border-color .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lightbox-nav:hover:not(:disabled){background:#ffffff24;border-color:#ffffff59;color:#fff}.lightbox-nav:disabled{opacity:.2;cursor:default}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}@media(max-width:1200px){.proj-details-pane{width:400px}}@media(max-width:1100px){.proj-details-pane{width:360px}}@media(max-width:992px){.proj-card{grid-template-columns:220px 1fr}.proj-modal-inner{flex-direction:column}.proj-iframe-pane{flex:none;height:50vh;border-right:none;border-bottom:1px solid var(--border-light)}.proj-details-pane{width:100%;flex:1}}@media(max-width:600px){.proj-card{grid-template-columns:1fr}.proj-thumb{height:180px}}
