.projectPage{overflow-x:clip}.projectGridSection{padding:clamp(1.5rem,3vw,2.5rem) 0 clamp(4rem,8vw,6rem)}.projectGridContainer{max-width:90%;position:relative}.projectGridIntro{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:clamp(2rem,4vw,3.25rem)}.projectGridEyebrow{margin:0 0 .8rem;color:hsla(0,0%,100%,.58);font-family:var(--font-ui);font-size:.9rem;letter-spacing:.24em;text-transform:uppercase}.projectGridIntro h1{margin:0 0 .9rem;color:#fff;font-family:var(--font-heading);font-size:clamp(2.9rem,7vw,5.6rem);letter-spacing:.08em;line-height:.94;text-transform:uppercase;text-wrap:balance}.projectGridLead{max-width:48rem;margin:0;color:hsla(0,0%,100%,.76);font-family:var(--font-body);font-size:1.02rem;line-height:1.85;-webkit-hyphens:auto;hyphens:auto;word-wrap:break-word}.projectGridStat{flex:0 0 auto;min-width:12rem;padding:1.2rem 1.35rem;border:1px solid rgba(0,0,0,.11);border-radius:1.4rem;background:rgba(0,0,0,.92);box-shadow:0 18px 50px rgba(0,0,0,.28)}.projectGridStat span{display:block;margin-bottom:.45rem;color:#fff;font-family:var(--font-numeric);font-size:clamp(2.9rem,5vw,4.6rem);line-height:.88}.projectGridStat p{margin:0;color:hsla(0,0%,100%,.72);font-family:var(--font-ui-light);font-size:.92rem;letter-spacing:.12em;text-transform:uppercase}.projectCardsGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));grid-gap:clamp(1.5rem,2vw,2rem);gap:clamp(1.5rem,2vw,2rem);align-items:stretch}.projectCard{position:relative;min-width:0;display:flex;flex-direction:column;height:100%;padding:1rem;border:1px solid rgba(0,0,0,.09);border-radius:1.8rem;background:#000;overflow:hidden;opacity:0;transform:translateY(1.2rem);transition:transform .26s ease,border-color .26s ease,box-shadow .26s ease,background .26s ease;animation:projectCardReveal .65s cubic-bezier(.22,1,.36,1) forwards;animation-delay:calc(var(--card-index) * 90ms)}.projectCard>*{position:relative;z-index:1}.projectCard:before{content:"";position:absolute;inset:-35% auto auto -15%;width:16rem;height:16rem;background:radial-gradient(circle,hsla(0,0%,100%,.14),transparent 70%);opacity:.18;pointer-events:none;transition:transform .26s ease,opacity .26s ease}.projectCardInteractive{cursor:pointer}.projectCardFeatured{border-color:hsla(0,0%,100%,.16);background:radial-gradient(circle at top right,hsla(0,0%,100%,.12),transparent 34%),linear-gradient(180deg,hsla(0,0%,6%,.88),rgba(6,6,6,.72)),rgba(0,0,0,.82);box-shadow:0 24px 60px rgba(0,0,0,.34),inset 0 1px 0 hsla(0,0%,100%,.14)}.projectCardFeatured:after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent,transparent 30%,hsla(0,0%,100%,.14) 45%,transparent 60%,transparent);transform:translateX(-135%);animation:projectPlatinumSweep 8s ease-in-out 1.1s infinite;pointer-events:none}.projectCardMedia{position:relative;overflow:hidden;aspect-ratio:16/10;margin-bottom:1.1rem;border:1px solid hsla(0,0%,100%,.08);border-radius:1.3rem;background:#060606}.projectCardMedia:after{content:"";position:absolute;inset:auto 0 0;height:50%;background:linear-gradient(180deg,transparent,rgba(0,0,0,.46));pointer-events:none}.projectCardMedia img,.projectCardMedia video{width:100%;height:100%;object-fit:cover;object-position:top;display:block;transform:scale(1.001);transition:transform .42s ease}.projectCardBadge,.projectCardNumber{position:absolute;z-index:1;display:inline-flex;align-items:center;justify-content:center;padding:.45rem .75rem;border-radius:999px;background:rgba(0,0,0,.56);color:#fff}.projectCardNumber{top:.85rem;left:.85rem;min-width:3.5rem;border:1px solid hsla(0,0%,100%,.16);font-family:var(--font-numeric);font-size:clamp(1.6rem,2vw,2.15rem);line-height:1}.projectCardBadge{top:.85rem;right:.85rem;border:1px solid hsla(0,0%,100%,.12);font-family:var(--font-ui-light);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase}.projectCardBody{min-width:0;display:flex;flex:1 1;flex-direction:column}.projectCardKicker{margin:0 0 .5rem;color:hsla(0,0%,100%,.62);font-family:var(--font-ui);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase}.projectCard h3{margin:0 0 .75rem;color:#fff;font-family:var(--font-heading);font-size:clamp(1.3rem,2vw,1.8rem);letter-spacing:.06em;line-height:1.05;text-transform:uppercase;text-wrap:balance}.projectCardTech{margin:0 0 .95rem;color:hsla(0,0%,100%,.82);font-family:var(--font-ui-light);font-size:.9rem;letter-spacing:.1em;line-height:1.5;text-transform:uppercase;word-break:break-word}.projectCardDescription{margin:0;color:hsla(0,0%,100%,.78);font-family:var(--font-body);line-height:1.8;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:5;line-clamp:5;-webkit-hyphens:auto;hyphens:auto;word-wrap:break-word}.projectCardHighlights{display:flex;flex-wrap:wrap;gap:.65rem;margin:1rem 0 0;padding:0;list-style:none}.projectCardHighlights li{padding:.55rem .9rem;border:1px solid hsla(0,0%,100%,.08);border-radius:999px;background:hsla(0,0%,100%,.04);color:hsla(0,0%,100%,.84);font-family:var(--font-ui-light);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase}.projectCardActions{display:flex;flex-wrap:nowrap;gap:.85rem;margin-top:1rem;padding-top:1.35rem;align-items:center}.projectCardActions .animated-button,.projectCardActions .projectCardButton,.projectCardActions .projectModalSecondaryButton{display:flex;justify-content:center;white-space:nowrap}.projectCardButton{align-self:flex-start;text-decoration:none}.projectLinkOutline{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 1.5rem;border:1px solid hsla(0,0%,100%,.3);border-radius:999px;color:#fff;font-size:.9rem;font-weight:700;font-family:var(--font-heading);text-transform:uppercase;text-decoration:none;background:transparent;width:max-content}.projectMore{padding:0 1.25rem clamp(4rem,7vw,5.5rem)}.projectMore h4{margin-bottom:.9rem;color:#fff;font-family:var(--font-heading);font-size:clamp(1.35rem,3vw,2rem);letter-spacing:.06em;text-transform:capitalize}.projectGithubLink{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;border:1px solid hsla(0,0%,100%,.14);border-radius:999px;background:hsla(0,0%,100%,.04);transition:transform .22s ease,border-color .22s ease,background-color .22s ease}.projectGithubLink svg{transition:transform .22s ease}.proj .animated-button{position:relative;display:inline-flex;align-items:center;gap:4px;padding:.95rem 2.15rem;border:4px solid transparent;border-radius:100px;background-color:inherit;color:#fff;box-shadow:0 0 0 2px #585858;cursor:pointer;overflow:hidden;transition:all .6s cubic-bezier(.23,1,.32,1);font-family:var(--font-ui-light);font-size:.96rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.proj .animated-button svg{position:absolute;width:24px;fill:#f7f7f7;z-index:1;transition:all .8s cubic-bezier(.23,1,.32,1)}.proj .animated-button .arr-1{right:16px}.proj .animated-button .arr-2{left:-25%}.proj .animated-button .circle{position:absolute;top:50%;left:50%;width:20px;height:20px;border-radius:50%;background-color:#fff;opacity:0;transform:translate(-50%,-50%);transition:all .8s cubic-bezier(.23,1,.32,1)}.proj .animated-button .text{position:relative;z-index:1;transform:translateX(-12px);transition:all .8s cubic-bezier(.23,1,.32,1)}.projectModal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.2rem}.projectModalBackdrop{position:absolute;inset:0;background:rgba(0,0,0,.78);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.projectModalPanel{width:min(1120px,100%);max-height:calc(100vh - 2.4rem);overflow:auto;padding:clamp(1.2rem,2vw,1.7rem);border:1px solid hsla(0,0%,100%,.14);border-radius:2rem;background:#0d0d0d;box-shadow:0 36px 120px rgba(0,0,0,.52);animation:projectModalReveal .32s cubic-bezier(.22,1,.36,1)}.projectCaseSheet>*,.projectModalPanel{position:relative;z-index:1}.projectModalClose{position:-webkit-sticky;position:sticky;top:0;z-index:2;margin-left:auto;display:grid;place-items:center;width:3.1rem;height:3.1rem;border:1px solid hsla(0,0%,100%,.14);border-radius:999px;background:hsla(0,0%,7%,.92);cursor:pointer}.projectModalClose span{position:absolute;width:1rem;height:1px;background:#fff}.projectModalClose span:first-child{transform:rotate(45deg)}.projectModalClose span:last-child{transform:rotate(-45deg)}.projectCaseHeader{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);grid-gap:clamp(1.15rem,2vw,1.8rem);gap:clamp(1.15rem,2vw,1.8rem);margin-top:-2rem}.projectCaseMeta{display:flex;flex-direction:column;justify-content:center}.projectCaseTitleRow{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem}.projectCaseStatus{display:inline-flex;align-items:center;min-height:2.3rem;padding:.45rem .85rem;border:1px solid hsla(0,0%,100%,.16);border-radius:999px;background:linear-gradient(180deg,hsla(0,0%,100%,.14),hsla(0,0%,100%,.04));color:#fff;font-family:var(--font-ui-light);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.projectModalMediaFrame{position:relative;overflow:hidden;min-height:24rem;border:1px solid hsla(0,0%,100%,.1);border-radius:1.7rem;background:#050505}.projectModalMediaFrame img,.projectModalMediaFrame video{width:100%;height:100%;object-fit:cover;display:block}.projectModalMediaFrame:after{content:"";position:absolute;inset:auto 0 0;height:55%;background:linear-gradient(180deg,transparent,rgba(0,0,0,.52));pointer-events:none}.projectModalTag{position:absolute;top:1rem;left:1rem;z-index:1;padding:.55rem .85rem;border:1px solid hsla(0,0%,100%,.16);border-radius:999px;background:rgba(0,0,0,.58);color:#fff;font-family:var(--font-ui-light);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase}.projectModalEyebrow{margin:0 0 .8rem;color:hsla(0,0%,100%,.62);font-family:var(--font-ui);font-size:.82rem;letter-spacing:.2em;text-transform:uppercase}.projectCaseMeta h2{margin:0;color:#fff;font-family:var(--font-heading);font-size:clamp(2.4rem,4.4vw,4.8rem);letter-spacing:.06em;line-height:.94;text-transform:uppercase}.projectModalLead{color:hsla(0,0%,100%,.92);font-size:1.08rem;-webkit-hyphens:auto;hyphens:auto;word-wrap:break-word}.projectModalLead,.projectModalOverview{margin:1rem 0 0;font-family:var(--font-body);line-height:1.85}.projectModalOverview{color:hsla(0,0%,100%,.72)}.projectModalFacts{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.25rem}.projectModalFacts span{display:inline-flex;align-items:center;padding:.65rem .95rem;border:1px solid hsla(0,0%,100%,.1);border-radius:999px;background:hsla(0,0%,100%,.04);color:hsla(0,0%,100%,.84);font-family:var(--font-ui-light);font-size:.82rem;letter-spacing:.1em;line-height:1.4;text-transform:uppercase}.projectModalActions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.6rem}.projectModalSecondaryButton{display:inline-flex;align-items:center;justify-content:center;min-height:3.5rem;padding:.95rem 1.6rem;border:1px solid hsla(0,0%,100%,.12);border-radius:999px;background:hsla(0,0%,100%,.04);color:#fff;font-family:var(--font-ui-light);font-size:.92rem;letter-spacing:.14em;text-transform:uppercase}.projectDetailLabel{margin:0 0 .65rem;color:hsla(0,0%,100%,.56);font-family:var(--font-ui);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase}.projectCaseSection h3,.projectCaseSection h4{margin:0 0 .8rem;color:#fff;font-family:var(--font-heading);letter-spacing:.05em;text-transform:uppercase}.projectCaseSection h3{font-size:clamp(1.35rem,2vw,1.9rem)}.projectCaseSection li,.projectCaseSection p,.projectRoleCard p,.projectStackRow p{color:hsla(0,0%,100%,.8);font-family:var(--font-body);line-height:1.85}.projectCaseSection{padding:1.45rem 0;border-top:1px solid hsla(0,0%,100%,.08)}.projectCaseSectionSplit{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1.25rem;gap:1.25rem}.projectCaseColumn{min-width:0}.projectCaseSectionHeader{margin-bottom:1rem}.projectBulletList,.projectCaseChecklist{margin:0;padding-left:1.2rem}.projectBulletList li+li,.projectCaseChecklist li+li,.projectWorkflowRail li+li{margin-top:.55rem}.projectBulletList li::marker,.projectCaseChecklist li::marker{color:hsla(0,0%,100%,.55)}.projectFeatureList,.projectRoleStrip,.projectStackList{display:grid;grid-gap:.9rem;gap:.9rem}.projectRoleStrip{grid-template-columns:repeat(3,minmax(0,1fr))}.projectFeatureList{grid-template-columns:repeat(2,minmax(0,1fr))}.projectFeatureItem,.projectRoleCard,.projectStackRow{min-width:0;padding:1.05rem 1.1rem;border:1px solid hsla(0,0%,100%,.08);border-radius:1.2rem;background:hsla(0,0%,100%,.025)}.projectRoleTitle{display:inline-flex;align-items:center;margin-bottom:.7rem;padding:.38rem .75rem;border-radius:999px;background:hsla(0,0%,100%,.06);color:#fff;font-family:var(--font-ui-light);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase}.projectFeatureItem p,.projectRoleCard p,.projectStackRow p{margin:0}.projectFeatureItem h4,.projectStackRow h4{font-size:1rem}.projectWorkflowRail{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.85rem 1rem;gap:.85rem 1rem;margin:0;padding:0;list-style:none}.projectWorkflowRail li{display:grid;grid-template-columns:auto 1fr;grid-gap:.85rem;gap:.85rem;min-width:0;padding:1rem 0;border-top:1px solid hsla(0,0%,100%,.08)}.projectWorkflowRail li span{color:hsla(0,0%,100%,.52);font-family:var(--font-numeric);font-size:1.8rem;line-height:1}.projectWorkflowRail li p{margin:0}.projectDetailConclusion{margin:0;font-size:1.02rem}@media (hover:hover) and (pointer:fine){.projectCard:hover{transform:translateY(-.45rem);border-color:hsla(0,0%,100%,.16);box-shadow:0 30px 75px rgba(0,0,0,.36)}.projectCard:hover:before{opacity:.28;transform:translate3d(.85rem,.55rem,0)}.projectCard:hover .projectCardMedia img,.projectCard:hover .projectCardMedia video{transform:scale(1.03)}.projectGithubLink:hover{transform:translateY(-.2rem);border-color:hsla(0,0%,100%,.24);background:hsla(0,0%,100%,.08)}.projectGithubLink:hover svg{transform:scale(1.08)}.proj .animated-button:hover{box-shadow:0 0 0 12px transparent;color:#212121;border-radius:12px}.proj .animated-button:hover .arr-1{right:-25%}.proj .animated-button:hover .arr-2{left:16px}.proj .animated-button:hover .text{transform:translateX(12px)}.proj .animated-button:hover svg{fill:#212121}.proj .animated-button:hover .circle{width:220px;height:220px;opacity:1}.projectModalClose:hover,.projectModalSecondaryButton:hover{border-color:hsla(0,0%,100%,.24);background:hsla(0,0%,100%,.08)}}.proj .animated-button:active{scale:.96;box-shadow:0 0 0 4px #adff2f}@keyframes projectCardReveal{0%{opacity:0;transform:translateY(1.2rem)}to{opacity:1;transform:translateY(0)}}@keyframes projectModalReveal{0%{opacity:0;transform:translateY(1rem) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes projectPlatinumSweep{0%,70%,to{transform:translateX(-135%)}30%{transform:translateX(135%)}}@media (max-width:1199px){.projectFeatureList,.projectRoleStrip,.projectWorkflowRail{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:991px){.projectGridIntro{flex-direction:column;align-items:flex-start}.projectGridStat{width:min(100%,18rem)}.projectCaseHeader{grid-template-columns:1fr;margin-top:-1.15rem}.projectModalMediaFrame{min-height:18rem}.projectCaseSectionSplit,.projectFeatureList,.projectRoleStrip,.projectWorkflowRail{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:767px){.projectGridContainer{max-width:94%}.projectCaseSectionSplit,.projectFeatureList,.projectRoleStrip,.projectWorkflowRail{grid-template-columns:1fr}}@media (max-width:640px){.projectGridSection{padding-bottom:4.2rem}.projectCardsGrid{grid-template-columns:1fr}.projectCard,.projectCardFeatured{padding:.9rem;border-radius:1.45rem}.projectCardFeatured .projectCardMedia,.projectCardMedia{aspect-ratio:16/10.2;border-radius:1rem}.projectCardDescription{-webkit-line-clamp:6;line-clamp:6}.projectCardActions,.projectModalActions{flex-direction:column;align-items:stretch}.projectCardButton,.projectModalActions .animated-button,.projectModalSecondaryButton{width:100%;justify-content:center}.projectModal{padding:.8rem}.projectModalPanel{padding:1rem;border-radius:1.4rem;max-height:calc(100vh - 1.6rem)}.projectCaseSection{padding:1.2rem 0}}@media (max-width:480px){.projectGridLead{font-size:.98rem;line-height:1.75}.projectCard h3,.projectCardFeatured h3{font-size:1.45rem}.projectCardTech,.projectModalFacts span{font-size:.78rem}.projectCardDescription,.projectCaseSection li,.projectCaseSection p,.projectModalLead,.projectModalOverview,.projectRoleCard p,.projectStackRow p{font-size:.98rem;line-height:1.7}.proj .animated-button{padding:.9rem 2rem;font-size:.88rem}.projectCaseMeta h2{font-size:clamp(2rem,11vw,2.8rem)}.projectCaseTitleRow{align-items:flex-start}}@media (prefers-reduced-motion:reduce){.proj .animated-button,.proj .animated-button .circle,.proj .animated-button .text,.proj .animated-button svg,.projectCard,.projectCard:before,.projectCardFeatured:after,.projectCardMedia img,.projectCardMedia video,.projectCaseSheet:before,.projectGithubLink,.projectGithubLink svg,.projectModalPanel{transition:none;animation:none}.projectCard{opacity:1;transform:none}}