.project-page{min-height:100vh;padding-top:4.5rem}.project-page .nav{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#060a12e0;padding:.65rem 0}.project-site-header-inner{flex-wrap:nowrap}.project-site-nav{margin-left:auto;margin-right:.5rem}.project-site-header-actions{margin-left:auto}.project-site-header-actions .project-page-nav-btn{color:var(--text);background:0 0;border-color:#ffffffb8}.project-site-header-actions .project-page-nav-btn:hover{color:#fff;background:#ffffff0f;border-color:#fff}.project-site-resume{padding-inline:.85rem}.project-site-mobile-actions{flex-direction:column;gap:.65rem;padding:1rem 1.25rem 1.5rem;display:flex}.project-site-mobile-actions .btn{justify-content:center;width:100%;text-decoration:none}.project-page-nav-btn{text-decoration:none}.project-page-nav-btn:hover{text-decoration:none;transform:translateY(-1px)}.project-page-hero{background:radial-gradient(70% 55% at 10% 0,#00b09724,#0000),radial-gradient(50% 40% at 95% 20%,#3774b11f,#0000);padding:2.5rem 0 2rem}.project-page-hero-grid{grid-template-columns:minmax(0,.9fr) minmax(0,1.35fr);align-items:center;gap:2rem;display:grid}.project-page-hero-focus{border-left:3px solid var(--gold);max-width:42ch;color:var(--text-muted);margin:1.25rem 0 0;padding-left:.85rem;font-size:.92rem;line-height:1.55}.project-page-hero-media{align-self:center;padding:.65rem;overflow:hidden}.project-page-hero-media .project-modal-carousel{margin-bottom:0}.project-page-hero-media .project-modal-carousel-viewport{border:1px solid var(--border);background:#eef2f7;border-radius:12px;line-height:0;overflow:hidden}.project-page-hero-media .project-modal-carousel-viewport img{vertical-align:top;width:100%;height:auto;display:block}.project-page-hero-media .project-modal-carousel-controls{margin-top:.65rem;padding-bottom:.1rem}.project-page-carousel .project-modal-carousel-viewport{line-height:0;overflow:hidden}.project-page-carousel .project-modal-carousel-viewport img{width:100%;height:auto;display:block}.project-page-gallery-shell figcaption{display:none}.project-page-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:0 0 .75rem;font-size:.78rem;font-weight:600}.project-page-hero h1{font-family:var(--font-display);letter-spacing:-.03em;margin:0;font-size:clamp(2rem,5vw,3.25rem);line-height:1.08}.project-page-subtitle{max-width:52ch;color:var(--text-muted);margin:.85rem 0 1.25rem;font-size:1.05rem}.project-page-tags{margin-top:.25rem}.project-page-section-title{font-family:var(--font-display);margin:0 0 1.25rem;font-size:clamp(1.35rem,3vw,1.85rem)}.project-page-gallery-shell{padding:1rem;overflow:hidden}.project-page-gallery-shell .project-screenshots-stack{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.project-page-body-grid{grid-template-columns:minmax(0,1.65fr) minmax(240px,.85fr);align-items:start;gap:1.5rem;display:grid}.project-page-main{padding:1.75rem}.project-page-description,.project-page-stack{color:var(--text-muted);margin:0 0 1rem;font-size:.98rem;line-height:1.75}.project-page-highlights{margin-top:1.25rem}.project-keyword{color:#7dd3c7;background:#00b09724;border:1px solid #00b09747;border-radius:.35em;padding:.05em .35em;font-weight:600}.section-tight,.project-page-architecture{padding-top:2rem;padding-bottom:2.5rem}.project-page-architecture-shell{max-width:960px;margin-inline:auto;padding:1.75rem}.project-page-architecture-shell .architecture-layers{margin-bottom:0}.project-page-architecture-shell .architecture-heading{font-family:var(--font-display);font-size:clamp(1.1rem,2.5vw,1.35rem)}.project-page-sidebar{flex-direction:column;gap:1rem;display:flex;position:sticky;top:5.5rem}.project-page-meta-card,.project-page-nav-card{padding:1.25rem 1.35rem}.project-page-meta-card h3,.project-page-nav-card h3{margin:0 0 1rem;font-size:.95rem}.project-page-meta-list{gap:.85rem;margin:0;display:grid}.project-page-meta-list dt{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0;font-size:.72rem;font-weight:700}.project-page-meta-list dd{color:var(--text);margin:.2rem 0 0;font-size:.9rem}.project-page-nav-link{border-top:1px solid var(--border);color:inherit;padding:.85rem 0;text-decoration:none;transition:color .15s;display:block}.project-page-nav-link:first-of-type{border-top:none;padding-top:0}.project-page-nav-link:hover{color:var(--accent);text-decoration:none}.project-page-nav-link-next{text-align:right}.project-page-nav-dir{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:.72rem;font-weight:700;display:block}.project-page-nav-title{margin-top:.25rem;font-weight:600;display:block}.project-page-related-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;display:grid}.project-page-related-card{color:inherit;grid-template-columns:72px minmax(0,1fr);align-items:center;gap:1rem;padding:1rem;text-decoration:none;transition:transform .2s,border-color .2s;display:grid}.project-page-related-card:hover{border-color:#00b09759;text-decoration:none;transform:translateY(-2px)}.project-page-related-card img{object-fit:cover;border:1px solid var(--border);border-radius:12px;width:72px;height:72px}.project-page-related-card h3{margin:0 0 .35rem;font-size:1rem}.project-page-related-card p{color:var(--text-muted);margin:0;font-size:.82rem;line-height:1.45}@media (width<=900px){.project-site-header-actions .project-page-nav-btn,.project-site-header-actions .project-site-resume{display:none}.project-page-hero-grid,.project-page-body-grid{grid-template-columns:1fr}.project-page-sidebar{position:static}}@media (width<=1100px){.project-site-nav{display:none}}@media (width<=640px){.project-page{padding-top:4rem}.project-page-gallery-shell .project-screenshots-stack{grid-template-columns:1fr}}.bg-mesh{z-index:-1;background:radial-gradient(ellipse 80% 50% at 20% -10%, #00b0972e, transparent), radial-gradient(ellipse 60% 40% at 90% 20%, #3774b11f, transparent), radial-gradient(ellipse 50% 30% at 50% 100%, #ffb0000f, transparent), var(--bg);position:fixed;inset:0}.nav{z-index:100;padding:1rem 0;transition:background .2s,border-color .2s,padding .2s;position:fixed;top:0;left:0;right:0}.nav-scrolled{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#060a12d9;padding:.65rem 0}.nav-inner{align-items:center;gap:1.5rem;display:flex}.nav-logo{font-family:var(--font-display);color:var(--text);font-size:1.35rem;font-weight:700;text-decoration:none}.nav-dot{color:var(--accent)}.nav-links{flex-wrap:wrap;gap:.35rem 1.25rem;margin-left:auto;display:flex}.nav-links a{color:var(--text-muted);font-size:.88rem;font-weight:500;text-decoration:none;transition:color .15s;position:relative}.nav-links a:hover{color:var(--accent)}.nav-links a.nav-link-active{color:var(--text);font-weight:600}.nav-links a.nav-link-active:after{content:"";background:var(--accent);border-radius:1px;height:2px;position:absolute;bottom:-6px;left:0;right:0}.nav-cta{flex-shrink:0}.nav-header-actions{flex-shrink:0;align-items:center;gap:.4rem;margin-left:auto;display:flex}.nav-header-actions .btn{white-space:nowrap;gap:.35rem;min-height:2.25rem;padding:.42rem .7rem;font-size:.8rem;font-weight:600;line-height:1;text-decoration:none}.nav-header-actions .btn:hover{text-decoration:none;transform:none}.nav-header-actions .btn-icon{width:14px;height:14px}.nav-resume-header{padding-inline:.55rem}.nav-menu-toggle{border:1px solid var(--border);width:2.25rem;height:2.25rem;color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;padding:0;transition:border-color .15s,background .15s;display:none}.nav-menu-toggle:hover{background:#00b09714;border-color:#00b09773}.nav-menu-bar{background:currentColor;border-radius:1px;width:1.1rem;height:2px;transition:transform .2s,opacity .2s;display:block}.nav-menu-open .nav-menu-toggle .nav-menu-bar:first-child{transform:translateY(7px)rotate(45deg)}.nav-menu-open .nav-menu-toggle .nav-menu-bar:nth-child(2){opacity:0}.nav-menu-open .nav-menu-toggle .nav-menu-bar:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.nav-mobile-panel{z-index:110;pointer-events:none;visibility:hidden;opacity:0;transition:opacity .2s,visibility .2s;position:fixed;inset:0}.nav-mobile-panel-open{pointer-events:auto;visibility:visible;opacity:1}.nav-mobile-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;opacity:0;background:#04080eb8;border:none;padding:0;transition:opacity .2s;position:absolute;inset:0}.nav-mobile-panel-open .nav-mobile-backdrop{opacity:1}.nav-mobile-sheet{background:linear-gradient(165deg,#0c121cfc 0%,#060a12fc 100%);border:1px solid #00b09738;border-radius:22px;flex-direction:column;gap:0;width:min(100% - 1.3rem,21.5rem);height:auto;padding:1.1rem 1rem 1rem;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:.65rem;bottom:.65rem;right:.65rem;overflow:hidden auto;transform:translate(calc(100% + 1rem));box-shadow:-8px 0 32px #00000073,inset 0 0 0 1px #ffffff0a}.nav-mobile-panel-open .nav-mobile-sheet{transform:translate(0)}.nav-drawer-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.65rem;display:flex}.nav-drawer-logo{font-size:1.35rem}.nav-drawer-close{border:1px solid var(--border);width:2.35rem;height:2.35rem;color:var(--text-muted);cursor:pointer;background:#ffffff0a;border-radius:10px;justify-content:center;align-items:center;padding:0;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.nav-drawer-close:hover{color:var(--text);background:#00b09714;border-color:#00b09766}.nav-drawer-divider{background:linear-gradient(90deg, var(--accent), #00b09733);border-radius:999px;width:2.5rem;height:3px;margin-bottom:.85rem}.nav-drawer-links{flex-direction:column;margin-bottom:1rem;display:flex}.nav-drawer-link{color:var(--text);border-bottom:1px solid #94a3b814;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;margin:0 -.35rem;padding:.8rem .65rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .15s,background .15s;display:grid;position:relative}.nav-drawer-link:last-child{border-bottom:none}.nav-drawer-link-glow{background:var(--accent);border-radius:0 4px 4px 0;width:3px;height:0;transition:height .2s;position:absolute;top:50%;left:0;transform:translateY(-50%);box-shadow:0 0 12px #00b097bf}.nav-drawer-link-active .nav-drawer-link-glow{height:70%}.nav-drawer-link-icon{width:2.25rem;height:2.25rem;color:var(--text-muted);background:#ffffff0a;border:1px solid #94a3b81a;border-radius:10px;justify-content:center;align-items:center;transition:color .15s,border-color .15s,background .15s;display:flex}.nav-drawer-link-chevron{color:var(--text-muted);opacity:.55}.nav-drawer-link-active{color:var(--accent);background:#00b0971a}.nav-drawer-link-active .nav-drawer-link-icon{color:var(--accent);background:#00b0971f;border-color:#00b09759}.nav-drawer-link-active .nav-drawer-link-chevron{color:var(--accent);opacity:1}.nav-drawer-cta{text-align:center;background:#00b0970d;border:1px solid #00b09747;border-radius:14px;margin-top:.25rem;padding:1.35rem .85rem .9rem;position:relative}.nav-drawer-cta-badge{background:var(--bg);width:2rem;height:2rem;color:var(--accent);border:1px solid #00b09759;border-radius:999px;justify-content:center;align-items:center;display:flex;position:absolute;top:-.85rem;left:50%;transform:translate(-50%);box-shadow:0 0 16px #00b09733}.nav-drawer-cta-title{font-family:var(--font-display);color:var(--text);margin:0 0 .4rem;font-size:1.05rem;font-weight:600;line-height:1.35}.nav-drawer-cta-accent{color:var(--accent)}.nav-drawer-cta-text{color:var(--text-muted);margin:0 0 .85rem;font-size:.78rem;line-height:1.45}.nav-drawer-cta-btn{border-radius:10px;justify-content:center;gap:.45rem;width:100%;font-weight:600;text-decoration:none}.nav-drawer-cta-btn:hover{text-decoration:none}.nav-drawer-social{border-top:1px solid #94a3b81a;margin-top:1.1rem;padding-top:.85rem}.nav-drawer-social-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:.5rem;margin:0 0 .75rem;font-size:.72rem;font-weight:600;display:flex}.nav-drawer-social-line{background:var(--accent);border-radius:1px;width:1.25rem;height:2px}.nav-drawer-social-row{justify-content:center;align-items:stretch;gap:0;display:flex}.nav-drawer-social-item{color:var(--text-muted);flex-direction:column;flex:1;align-items:center;gap:.4rem;padding:.35rem .25rem;font-size:.72rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.nav-drawer-social-item:hover{color:var(--accent);text-decoration:none}.nav-drawer-social-icon{width:2.5rem;height:2.5rem;color:var(--text);background:#ffffff0a;border:1px solid #94a3b81f;border-radius:10px;justify-content:center;align-items:center;transition:border-color .15s,background .15s,color .15s;display:flex}.nav-drawer-social-item:hover .nav-drawer-social-icon{color:var(--accent);background:#00b0971a;border-color:#00b09759}.nav-drawer-social-sep{background:#94a3b826;align-self:center;width:1px;height:2.5rem}.nav-drawer-footer{text-align:center;color:var(--text-muted);border-top:1px solid #94a3b814;margin:1rem 0 0;padding-top:.75rem;font-size:.68rem}.nav-drawer-footer span{color:var(--accent);font-weight:600}@media (width<=900px){.nav-links-desktop{display:none}.nav-header-actions{gap:.3rem}.nav-header-actions .btn{gap:.28rem;min-height:2.15rem;padding:.38rem .5rem;font-size:.72rem}.nav-header-actions .btn-icon{width:13px;height:13px}.nav-resume-header{padding-inline:.45rem}.nav-menu-toggle{width:2.15rem;height:2.15rem;margin-left:.15rem;display:inline-flex}.nav-inner{align-items:center;gap:.35rem}}.hero{align-items:center;min-height:92vh;padding-top:5.5rem;scroll-margin-top:4.5rem;display:flex}.hero-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);align-items:center;gap:2.5rem;display:grid}.hero-copy{width:100%;max-width:none}@media (width<=900px){.hero-grid{text-align:center;grid-template-columns:1fr}}.hero-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 .75rem;font-size:.8rem;font-weight:600}.hero-title{font-family:var(--font-display);letter-spacing:-.03em;margin:0 0 .5rem;font-size:clamp(2.25rem,5vw,3.25rem);font-weight:700;line-height:1.1}.text-gradient{background:linear-gradient(135deg, var(--accent), #5eead4);color:#0000;-webkit-background-clip:text;background-clip:text}.hero-role-pills{flex-wrap:wrap;gap:.5rem;margin:0 0 1rem;display:flex}.hero-role-pill{color:var(--accent);background:#00b0971f;border:1px solid #00b09759;border-radius:999px;margin:0;padding:.4rem .85rem;font-size:.88rem;font-weight:600;display:inline-block}@media (width<=900px){.hero-role-pills{justify-content:center}}.hero-badges{flex-wrap:wrap;gap:.55rem;width:100%;margin:0 0 1.15rem;display:flex}.hero-badge{border-radius:10px;flex:11.5rem;align-items:center;gap:.55rem;min-width:0;padding:.55rem .7rem;display:flex}.hero-badge-gold{background:#ffb00014;border-color:#e8c54766}.hero-badge-gold .hero-badge-icon{color:#e8c547}.hero-badge-violet{background:#8b5cf61a;border-color:#a78bfa59}.hero-badge-violet .hero-badge-icon{color:#c4b5fd}.hero-badge-teal{background:#00b09714;border-color:#00b09759}.hero-badge-teal .hero-badge-icon{color:#5eead4}.hero-badge-icon{flex-shrink:0;width:1.35rem;height:1.35rem}.hero-badge-text{min-width:0}.hero-badge-title{color:var(--text);margin:0;font-size:.8rem;font-weight:600;line-height:1.25}.hero-badge-detail{color:var(--text-muted);margin:.1rem 0 0;font-size:.7rem;line-height:1.25}.hero-tagline{color:var(--text-muted);max-width:none;margin:0 0 1.25rem;font-size:1.05rem;line-height:1.65}@media (width<=900px){.hero-tagline{margin-inline:auto}}.hero-stats{flex-wrap:wrap;gap:1.75rem 2.5rem;margin:0 0 1.5rem;display:flex}.hero-stat{flex-direction:column;gap:.2rem;display:flex}.hero-stat-value{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;font-size:clamp(1.75rem,3.5vw,2.25rem);font-weight:700;line-height:1}.hero-stat-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:.72rem;font-weight:600}.hero-mercor-note{color:var(--text-muted);margin:-.35rem 0 1.35rem;font-size:.88rem;line-height:1.55}.hero-mercor-note strong{color:var(--accent);font-weight:600}@media (width<=900px){.hero-stats{justify-content:center}.hero-mercor-note{text-align:center}.hero-badges{justify-content:center}}.hero-actions{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.hero-resume-btn,.hero-resume-btn:hover{text-decoration:none}@media (width<=900px){.hero-actions{justify-content:center}}.hero-meta{color:var(--text-muted);font-size:.88rem}.meta-sep{margin:0 .5rem}.hero-visual{justify-content:center;align-items:center;display:flex;position:relative;overflow:visible}.hero-image-ring{background:linear-gradient(135deg, var(--accent), var(--blue), var(--gold));border-radius:50%;flex-shrink:0;padding:6px}.hero-image{object-fit:cover;border:4px solid var(--bg);border-radius:50%;width:300px;max-width:min(300px,100%);height:300px;max-height:min(300px,100%)}@media (width<=900px){.hero-visual{justify-content:center;margin-top:.5rem}.hero-image{width:min(300px,72vw);height:min(300px,72vw)}}.hero-float{padding:.75rem 1rem;font-size:.8rem;position:absolute}.float-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.float-label-centered{text-align:center;text-transform:none;letter-spacing:.04em;width:100%;display:block}.hero-award{text-align:center;flex-direction:column;align-items:center;margin-top:.4rem;display:flex}.hero-award-medal{filter:drop-shadow(0 6px 14px #d4a01773);display:block}.hero-award-text{letter-spacing:.02em;color:#e8c547;margin:.4rem 0 0;font-size:.72rem;font-weight:600;line-height:1.3}.hero-float-1{padding:.85rem 1rem 1rem;top:6%;left:-6%}@media (width<=900px){.hero-float{display:none}}.section-alt{background:#0f172a59}.section-intro{color:var(--text-muted);max-width:40rem;margin:-.5rem 0 2.5rem}.about-tabs-wrap{width:100%;max-width:none}.about-tabs{border-bottom:1px solid var(--border);grid-template-columns:repeat(3,minmax(0,1fr));gap:0;display:grid}@media (width<=640px){.about-tabs{grid-template-columns:1fr}}.about-tab{min-height:3.25rem;color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;border:none;justify-content:center;align-items:center;padding:.85rem .75rem;font-size:.82rem;font-weight:500;line-height:1.35;transition:color .15s;display:flex;position:relative}@media (width>=900px){.about-tab{min-height:3.5rem;font-size:.9rem}}.about-tab:hover{color:var(--text)}.about-tab-active{color:var(--text);font-weight:600}.about-tab-active:after{content:"";background:var(--text);height:2px;position:absolute;bottom:-1px;left:0;right:0}.about-panel{border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;padding:1.35rem 1.5rem 1.5rem}.about-panel-title{color:var(--accent);margin:0 0 1rem;font-size:1rem;font-weight:600}.about-panel p{color:var(--text-muted);margin:0 0 1rem;font-size:.92rem;line-height:1.65}.about-panel p:last-of-type{margin-bottom:0}.about-kw{color:var(--accent);font-weight:600}.about-projects{flex-direction:column;gap:1rem;margin-top:1.15rem;display:flex}.about-project{border:1px solid var(--border);background:#ffffff05;border-radius:10px;padding:1rem 1.1rem}.about-project-head{flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;margin:0 0 .55rem;font-size:.92rem;font-weight:600;line-height:1.35;display:flex}.about-project-name{color:var(--text)}.about-project-sep{color:var(--text-muted);font-weight:400}.about-project-client{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-size:.78rem;font-weight:600}.about-project p{margin:0;font-size:.88rem;line-height:1.6}.about-meta-block{margin-top:1.15rem}.about-meta-block:first-of-type{margin-top:1.25rem}.about-meta-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-size:.72rem;font-weight:600;display:block}.about-chips{flex-wrap:wrap;gap:.4rem;display:flex}.about-chip{color:var(--text);background:#00b0971f;border:1px solid #00b09740;border-radius:999px;padding:.3rem .65rem;font-size:.78rem;font-weight:500}.about-chip-client{border-color:var(--border);color:var(--text-muted);background:#ffffff0a}.about-education .about-school{color:var(--text);margin:0 0 .25rem;font-weight:600}.about-school{margin:0 0 .25rem;font-weight:600}.about-muted{color:var(--text-muted);margin:.5rem 0 0;font-size:.9rem}.experience-meta-inline{color:var(--text-muted);font-size:.78rem;font-weight:500}.experience-role{color:var(--accent);margin:-.35rem 0 .85rem;font-size:.88rem}.experience-bullets{color:var(--text-muted);margin:0;padding-left:1.15rem;font-size:.92rem;line-height:1.65}.experience-bullets li{margin-bottom:.55rem}.experience-bullets li:last-child{margin-bottom:0}@media (width<=640px){.about-tabs-dynamic{grid-template-columns:1fr!important}}.project-featured{grid-template-columns:1.1fr 1fr;gap:0;margin-bottom:2.5rem;display:grid;overflow:hidden}@media (width<=900px){.project-featured{grid-template-columns:1fr}}.project-featured-media{background:var(--bg-elevated);min-height:280px;position:relative}.project-featured-media>img{object-fit:cover;width:100%;height:100%;min-height:280px}.project-screenshots{width:100%}.project-screenshot-figure{margin:0}.project-screenshot-figure img{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;height:auto;display:block}.project-screenshot-figure figcaption{color:var(--text-muted);text-align:center;margin-top:.35rem;font-size:.72rem}.project-screenshots-stack{flex-direction:column;gap:.85rem;max-height:none;padding:.85rem;display:flex;overflow:visible}.project-screenshots-carousel{flex-direction:column;padding:.75rem;display:none}.project-screenshots-carousel-viewport{position:relative}.project-screenshots-carousel-controls{justify-content:center;align-items:center;gap:.75rem;margin-top:.65rem;display:flex}.project-screenshots-nav{border:1px solid var(--border);width:2rem;height:2rem;color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:999px;font-size:1.25rem;line-height:1;transition:background .15s,border-color .15s}.project-screenshots-nav:hover{border-color:var(--accent);background:#ffffff14}.project-screenshots-dots{gap:.4rem;display:flex}.project-screenshots-dot{background:var(--border);cursor:pointer;border:none;border-radius:999px;width:.45rem;height:.45rem;padding:0;transition:background .15s,transform .15s}.project-screenshots-dot-active{background:var(--accent);transform:scale(1.2)}.project-screenshots-counter{color:var(--text-muted);text-align:center;margin:.35rem 0 0;font-size:.72rem}@media (width<=900px){.project-screenshots-stack{display:none}.project-screenshots-carousel{display:flex}}@media (width>=901px){.project-featured-media:has(.project-screenshots){align-self:stretch;max-height:none;overflow-y:auto}}.project-featured-body{padding:2rem}.project-client{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin:0 0 .5rem;font-size:.8rem}.project-featured-body h3{font-family:var(--font-display);margin:0 0 .35rem;font-size:1.75rem}.project-subtitle{color:var(--text-muted);margin:0 0 1.25rem}.project-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem;display:flex}.project-stack-summary{color:var(--text-muted);background:#00b0970f;border:1px solid #00b09733;border-radius:12px;margin:0 0 1.5rem;padding:1rem 1.15rem;font-size:.95rem;line-height:1.65}.architecture-layers{margin-bottom:1.5rem}.architecture-heading{color:var(--text);margin:0 0 .35rem;font-size:1rem;font-weight:600}.architecture-subtitle{color:var(--text-muted);margin:0 0 1rem;font-size:.9rem}.architecture-tabs{border-bottom:1px solid var(--border);grid-template-columns:repeat(3,minmax(0,1fr));gap:0;margin-bottom:0;display:grid}@media (width<=640px){.architecture-tabs{grid-template-columns:1fr}}.architecture-tab{min-height:3.25rem;color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;border:none;justify-content:center;align-items:center;padding:.85rem .5rem;font-size:.8rem;font-weight:500;line-height:1.35;transition:color .15s;display:flex;position:relative}@media (width>=900px){.architecture-tab{min-height:3.5rem;padding:.9rem .65rem;font-size:.88rem}}.architecture-tab:hover{color:var(--text)}.architecture-tab-active{color:var(--text);font-weight:600}.architecture-tab-active:after{content:"";background:var(--text);height:2px;position:absolute;bottom:-1px;left:0;right:0}.architecture-panel{border:1px solid var(--border);background:#ffffff05;border-top:none;border-radius:0 0 12px 12px;padding:1.15rem 1.25rem;position:relative;overflow:hidden}.architecture-panel-layout{min-height:7.5rem;position:relative}.architecture-panel-has-ribbon .architecture-panel-copy{padding-right:2.25rem}.architecture-panel-copy{z-index:1;max-width:100%;position:relative}.architecture-panel-title{color:var(--accent);margin:0 0 .5rem;font-size:.9rem;font-weight:600}.architecture-panel-copy p{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.65}@keyframes architecture-ribbon-bounce{0%,to{transform:translate(0)}50%{transform:translate(-3px)}}.architecture-panel-ribbon{z-index:3;pointer-events:none;position:absolute;inset:0}.architecture-panel-ribbon-handle{z-index:5;pointer-events:auto;cursor:pointer;background:#fff;border:1px solid #d4d4d4;border-right:none;border-radius:8px 0 0 8px;justify-content:center;align-items:center;width:1.75rem;height:3.5rem;transition:background .15s;display:flex;position:absolute;top:.35rem;right:0;box-shadow:-2px 0 10px #0000001f}.architecture-panel-ribbon-handle-bounce{animation:2.5s ease-in-out infinite architecture-ribbon-bounce}.architecture-panel-ribbon-handle:hover{background:#fafafa}@media (prefers-reduced-motion:reduce){.architecture-panel-ribbon-handle-bounce{animation:none}}.architecture-panel-ribbon-chevron{color:#000;font-size:1.25rem;font-weight:700;line-height:1}.architecture-panel-ribbon-drawer{z-index:4;border:1px solid var(--border);opacity:0;visibility:hidden;pointer-events:none;background:#fff;justify-content:center;align-items:flex-start;padding:.65rem 2rem .65rem .65rem;transition:transform .3s ease-out,opacity .2s,visibility .2s;display:flex;position:absolute;inset:0;overflow:auto;transform:translate(100%)}.architecture-panel-ribbon-open .architecture-panel-ribbon-drawer{opacity:1;visibility:visible;pointer-events:auto;transform:translate(0)}.architecture-panel-ribbon-drawer img{object-fit:contain;border-radius:6px;width:100%;max-width:100%;height:auto;display:block}.project-highlights{color:var(--text-muted);margin:0;padding-left:1.15rem;font-size:.92rem}.project-highlights li{margin-bottom:.45rem}.project-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.project-grid-toolbar{justify-content:space-between;align-items:flex-end;gap:1rem;margin:0 0 1rem;display:flex}.projects-subhead{color:var(--text);margin:0;font-size:1.05rem}.projects-note{color:var(--text-muted);margin:.3rem 0 0;font-size:.86rem}.project-filter-wrap{align-items:center;gap:.5rem;display:flex}.project-filter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}.project-filter{border:1px solid var(--border);color:#fff;background:#0f172ae0;border-radius:8px;outline:none;min-width:130px;padding:.45rem .7rem;font-size:.88rem}.project-filter:focus{border-color:var(--accent)}@media (width<=700px){.project-grid-toolbar{flex-direction:column;align-items:flex-start}}.project-card{transition:transform .2s,border-color .2s;overflow:hidden}.project-card-clickable{cursor:pointer}.project-card-clickable:hover,.project-card:hover{border-color:#00b09759;transform:translateY(-4px)}.project-featured-media.project-card-clickable{cursor:pointer}.project-featured-media.project-card-clickable:hover{opacity:.95}.project-card-media{aspect-ratio:16/10;background:var(--bg-elevated);overflow:hidden}.project-card-media img{object-fit:cover;width:100%;height:100%}.project-card-carousel{background:#f8fafc;width:100%;height:100%;position:relative}.project-card-carousel img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.project-card-carousel-dots{background:#0f172a8c;border-radius:999px;gap:.35rem;padding:.2rem .45rem;display:flex;position:absolute;bottom:.5rem;left:50%;transform:translate(-50%)}.project-card-carousel-dot{background:#ffffff73;border-radius:999px;width:.35rem;height:.35rem}.project-card-carousel-dot-active{background:var(--accent);transform:scale(1.2)}.project-card-body{padding:1.25rem}.project-period{color:var(--text-muted);font-size:.75rem}.project-card-body h3{margin:.35rem 0 .25rem;font-size:1.1rem}.project-card-body>p{color:var(--text-muted);margin:0 0 .75rem;font-size:.88rem}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.skills-card{background:#141f34d1;border-color:#f1f5f929;padding:1.35rem}.skills-card h3{color:#fff;align-items:center;gap:.55rem;margin:0 0 1rem;font-size:.95rem;display:flex}.skills-group-icon{fill:currentColor;opacity:.95;width:1rem;height:1rem}.skills-list{flex-wrap:wrap;gap:.4rem;display:flex}.skills-list span{color:#fff;background:#ffffff1a;border:1px solid #f1f5f94d;border-radius:8px;padding:.35rem .7rem;font-size:.82rem;font-weight:500}.contact-section{min-height:calc(100dvh - 4.5rem);padding-top:.5rem;padding-bottom:4rem}.contact-layout{padding-top:.25rem}.contact-header{margin-bottom:1.5rem}.contact-row{grid-template-columns:minmax(0,1fr) minmax(260px,340px);align-items:start;gap:1.25rem 1.75rem;display:grid}.contact-slider-col{min-width:0}.contact-title{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text);margin:0 0 1rem;font-size:clamp(2rem,4.5vw,3rem);font-weight:600;line-height:1.08}.contact-title-accent{color:var(--accent);font-style:italic}.contact-title-dot{color:var(--text)}.contact-lead{color:var(--text-muted);max-width:36rem;margin:0 0 1rem;font-size:1.02rem;line-height:1.55}@media (width>=768px){.contact-lead{white-space:nowrap;font-size:1.08rem}}.contact-usp-slider{aspect-ratio:1024/682;background:#080c12;border-radius:14px;width:100%;margin:0;position:relative;overflow:hidden}.contact-usp-slider-track{will-change:transform;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1);display:flex}.contact-usp-slide{border-color:#00b09733;flex:0 0 100%;min-width:100%;height:100%;padding:0;overflow:hidden}.contact-usp-slide-media{background:#080c12;width:100%;height:100%;margin:0;padding:0;line-height:0;overflow:hidden}.contact-usp-slide-media img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.contact-usp-slide-copy{padding:1rem 1.1rem 1.15rem}.contact-usp-slide-copy h3{font-family:var(--font-display);color:var(--text);margin:0 0 .35rem;font-size:1.15rem;font-weight:600}.contact-usp-slide-copy p{color:var(--text-muted);margin:0;font-size:.86rem;line-height:1.55}.contact-usp-slide-emphasis{border-color:#00b09773}.contact-usp-slide-active.contact-usp-slide-emphasis{box-shadow:0 0 28px #00b0971f}.contact-usp-dots{justify-content:center;gap:.45rem;margin-top:.65rem;display:flex}.contact-usp-dot{background:var(--border);cursor:pointer;border:none;border-radius:999px;width:.45rem;height:.45rem;padding:0;transition:background .15s,transform .15s}.contact-usp-dot-active{background:var(--accent);transform:scale(1.15)}@media (prefers-reduced-motion:reduce){.contact-usp-slider-track{transition:none}}.contact-status-pill{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a;border-radius:999px;align-items:center;gap:.5rem;margin-top:.25rem;padding:.45rem .85rem;font-size:.82rem;font-weight:500;display:inline-flex}.contact-location{color:var(--accent);margin:1rem 0 0;font-size:.88rem;font-weight:500}.contact-status-dot{background:var(--accent);border-radius:999px;width:.45rem;height:.45rem;box-shadow:0 0 8px #00b097a6}.contact-cards{flex-direction:column;gap:.75rem;display:flex}.contact-link-card{align-items:center;gap:1rem;padding:1rem 1.1rem;text-decoration:none;transition:transform .15s,border-color .15s,background .15s;display:flex}.contact-link-card:hover{background:#00b0970f;border-color:#00b09759;transform:translateY(-2px)}.contact-link-icon-wrap{width:2.5rem;height:2.5rem;color:var(--accent);background:#00b0971f;border:1px solid #00b09740;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-link-icon{width:1.15rem;height:1.15rem}.contact-link-text{flex-direction:column;gap:.2rem;min-width:0;display:flex}.contact-link-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:.72rem;font-weight:600}.contact-link-value{color:var(--text);word-break:break-all;font-size:.92rem;font-weight:600}.contact-link-click-here{color:#fff;text-underline-offset:3px;word-break:normal;text-decoration:underline}.contact-footer{text-align:center;color:#fff;margin:3rem 0 0;font-size:.92rem}.contact-footer-git{color:#fff;letter-spacing:.02em;font-family:ui-monospace,Cascadia Code,SF Mono,Menlo,Consolas,monospace;font-size:.95rem;font-weight:500}.contact-footer-cmd{color:#fff;text-decoration:underline;-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent);text-underline-offset:4px;font-weight:600;text-decoration-thickness:2px}.contact-footer-msg{color:#fff;font-weight:700}@media (width<=900px){.contact-row{grid-template-columns:1fr;gap:1.5rem}.contact-lead{white-space:normal;max-width:none}}.project-card-link{color:inherit;text-decoration:none;display:block}.project-card-link:hover{text-decoration:none}.project-featured-link{color:inherit;text-decoration:none;display:block}.project-inline-link{color:inherit;text-decoration:none}.project-inline-link:hover{color:var(--accent);text-decoration:none}.project-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#020617d1;justify-content:center;align-items:center;padding:1.25rem;display:flex;position:fixed;inset:0}.project-modal{border-radius:16px;width:min(920px,100%);max-height:min(92vh,900px);padding:1.5rem 1.75rem 1.75rem;position:relative;overflow:auto}.project-modal-close{z-index:2;border:1px solid var(--border);width:2.25rem;height:2.25rem;color:var(--text);cursor:pointer;background:#ffffff0f;border-radius:999px;font-size:1.35rem;line-height:1;transition:background .15s,border-color .15s;position:absolute;top:1rem;right:1rem}.project-modal-close:hover{border-color:var(--accent);background:#ffffff1f}.project-modal-header{margin-bottom:1rem;padding-right:2.5rem}.project-modal-client{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0 0 .35rem;font-size:.75rem}.project-modal-header h2{font-family:var(--font-display);margin:0 0 .35rem;font-size:1.65rem}.project-modal-subtitle{color:var(--text-muted);margin:0;font-size:.92rem}.project-modal-carousel{margin-bottom:1.25rem}.project-modal-carousel-viewport{border:1px solid var(--border);background:#f8fafc;border-radius:12px;overflow:hidden}.project-modal-carousel-viewport img{object-fit:cover;object-position:center;width:100%;max-height:min(52vh,480px);display:block}.project-modal-carousel-caption{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);background:#ffffff0a;margin:0;padding:.5rem .75rem;font-size:.78rem;font-weight:600}.project-modal-carousel-controls{justify-content:center;align-items:center;gap:.65rem;margin-top:.65rem;display:flex}.project-modal-carousel-nav{border:1px solid var(--border);width:2rem;height:2rem;color:var(--text);cursor:pointer;background:#ffffff0d;border-radius:999px;font-size:1.15rem;line-height:1}.project-modal-carousel-nav:hover{border-color:var(--accent)}.project-modal-carousel-dots{gap:.4rem;display:flex}.project-modal-carousel-dot{background:var(--border);cursor:pointer;border:none;border-radius:999px;width:.45rem;height:.45rem;padding:0}.project-modal-carousel-dot-active{background:var(--accent);transform:scale(1.15)}.project-modal-carousel-counter{color:var(--text-muted);text-align:right;min-width:2.5rem;font-size:.75rem}.project-modal-fallback-media{border:1px solid var(--border);border-radius:12px;margin-bottom:1.25rem;overflow:hidden}.project-modal-fallback-media img{width:100%;display:block}.project-modal-body p{color:var(--text-muted);margin:0 0 1rem;font-size:.95rem;line-height:1.7}.project-modal-tags{flex-wrap:wrap;gap:.4rem;display:flex}:root{--bg:#060a12;--bg-elevated:#0f172a;--bg-card:#0f172ab8;--border:#94a3b81f;--text:#f1f5f9;--text-muted:#94a3b8;--accent:#00b097;--accent-soft:#00b09726;--gold:#ffb000;--blue:#3774b1;--font-sans:"DM Sans", system-ui, sans-serif;--font-display:"Fraunces", Georgia, serif;--radius:16px;--max:1120px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:4.5rem}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;line-height:1.6}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.container{width:min(var(--max), calc(100% - 2.5rem));margin-inline:auto}.section{padding:1.5rem 0 5rem;scroll-margin-top:4.5rem}.section-label{letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.75rem;font-weight:600;display:inline-block}.section-title{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 1rem;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:600}.glass{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn{cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.35rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .15s,box-shadow .15s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg, var(--accent), #008f7a);color:#fff;box-shadow:0 8px 24px #00b09759}.btn-outline{color:var(--text);border:1px solid var(--border);background:0 0}.btn-with-icon .btn-icon{flex-shrink:0}.tag{background:var(--accent-soft);color:#7dd3c7;border:1px solid #00b09740;border-radius:999px;padding:.25rem .65rem;font-size:.72rem;font-weight:500;display:inline-block}
