body[data-page=portfolio]{background:radial-gradient(circle at 0 0,#22d3ee24,#0000 26rem),radial-gradient(circle at 100% 0,#fbbf241f,#0000 24rem),#020617}.site-shell{--tw-bg-opacity:1;background-color:rgb(2 6 23/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(241 245 249/var(--tw-text-opacity,1));position:relative;overflow:hidden}.hero-orb{--tw-blur:blur(64px);width:18rem;height:18rem;filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);background-color:#22d3ee1a;border-radius:9999px;position:absolute}.hero-orb-secondary{background-color:#fcd34d1a}.section-label{text-transform:uppercase;letter-spacing:.28em;--tw-text-opacity:1;color:rgb(165 243 252/var(--tw-text-opacity,1));background-color:#ffffff0d;border-width:1px;border-color:#ffffff1a;border-radius:9999px;align-items:center;padding:.5rem 1rem;font-size:.75rem;font-weight:600;line-height:1rem;display:inline-flex}.nav-link-site{--tw-text-opacity:1;color:rgb(203 213 225/var(--tw-text-opacity,1));font-size:.875rem;font-weight:500;line-height:1.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.nav-link-site:hover,.nav-link-site.is-active{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}[data-portfolio-nav].is-scrolled{--tw-shadow:0 18px 60px #02061752;--tw-shadow-colored:0 18px 60px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);background-color:#020617f2}.glass-panel{--tw-shadow:0 24px 80px #02061759;--tw-shadow-colored:0 24px 80px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);--tw-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:#ffffff0f;border-width:1px;border-color:#ffffff1a;border-radius:2rem;padding:1.25rem}.hero-photo-card{min-height:42rem}.hero-photo-image{-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;border-radius:1.75rem;width:100%;height:100%;min-height:34rem}.hero-photo-fallback{background-color:#0f172ab3;border:1px dashed #ffffff26;border-radius:1.75rem;flex-direction:column;justify-content:flex-end;min-height:34rem;padding:2rem;display:flex}.hero-photo-meta{--tw-shadow:0 20px 45px #02061759;--tw-shadow-colored:0 20px 45px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);--tw-backdrop-blur:blur(16px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:#0206178c;border-width:1px;border-color:#ffffff1a;border-radius:1.5rem;padding:1.25rem;position:absolute;bottom:2rem;left:2rem;right:2rem}.project-card{--tw-shadow:0 24px 80px #02061747;--tw-shadow-colored:0 24px 80px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);--tw-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:#0f172aa6;border-width:1px;border-color:#ffffff1a;border-radius:2rem;padding:1.5rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.project-card:hover{--tw-translate-y:-.25rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));background-color:#0f172abf;border-color:#67e8f933}.project-card-thumbnail{aspect-ratio:16/10;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;border-radius:1.5rem;width:100%;margin-bottom:1.25rem}.project-media-hint{justify-content:flex-start;display:flex}.project-detail-trigger{--tw-text-opacity:1;color:rgb(207 250 254/var(--tw-text-opacity,1));background-color:#22d3ee1a;border-width:1px;border-color:#67e8f933;border-radius:9999px;justify-content:center;align-items:center;padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;line-height:1.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1);display:inline-flex}.project-detail-trigger:hover{background-color:#22d3ee26;border-color:#67e8f959}body[data-page=portfolio].is-modal-open{overflow:hidden}.project-modal{pointer-events:none;z-index:70;opacity:0;padding:1.5rem 1rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,.2,1);position:fixed;inset:0}@media (width>=640px){.project-modal{padding-left:1.5rem;padding-right:1.5rem}}@media (width>=1024px){.project-modal{padding-left:2rem;padding-right:2rem}}.project-modal{visibility:hidden}.project-modal.is-active{pointer-events:auto;opacity:1;visibility:visible}.project-modal-backdrop{--tw-backdrop-blur:blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:#020617cc;position:absolute;inset:0}.project-modal-panel{--tw-shadow:0 32px 120px #02061799;--tw-shadow-colored:0 32px 120px var(--tw-shadow-color);max-width:64rem;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);background-color:#020617f2;border-width:1px;border-color:#ffffff1a;border-radius:2rem;max-height:calc(100vh - 3rem);margin-left:auto;margin-right:auto;position:relative;overflow:hidden}.project-modal-scroll{max-height:calc(100vh - 3rem);overflow-y:auto}.project-modal-close{z-index:10;--tw-text-opacity:1;width:2.75rem;height:2.75rem;color:rgb(255 255 255/var(--tw-text-opacity,1));background-color:#020617b3;border-width:1px;border-color:#ffffff1a;border-radius:9999px;justify-content:center;align-items:center;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1);display:inline-flex;position:absolute;top:1rem;right:1rem}.project-modal-close:hover{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.project-modal-content{gap:1.5rem;padding:1.25rem;display:grid}@media (width>=640px){.project-modal-content{padding:1.5rem}}@media (width>=1024px){.project-modal-content{grid-template-columns:1.05fr .95fr;padding:2rem}}.project-modal-cover{aspect-ratio:16/10;--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1));-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;border-width:1px;border-color:#ffffff1a;border-radius:1.5rem;width:100%}.project-modal-gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}@media (width>=640px){.project-modal-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}}.project-modal-gallery-button{background-color:#0f172ab3;border-width:1px;border-color:#ffffff1a;border-radius:1rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,.2,1);overflow:hidden}.project-modal-gallery-button:hover{--tw-translate-y:-.125rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));border-color:#67e8f94d}.project-modal-gallery-button.is-active{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000);--tw-ring-color:#67e8f933;border-color:#67e8f980}.project-modal-gallery-image{aspect-ratio:1;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;width:100%}.project-modal-empty{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1));background-color:#ffffff08;border:1px dashed #ffffff1a;border-radius:1.5rem;padding:1.25rem 1rem;font-size:.875rem;line-height:1.75rem}.project-modal-body{align-self:flex-start}.skill-card{--tw-shadow:0 16px 50px #02061740;--tw-shadow-colored:0 16px 50px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);--tw-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:#ffffff0a;border-width:1px;border-color:#ffffff1a;border-radius:2rem;padding:1.5rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.skill-card:hover{--tw-translate-y:-.25rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));border-color:#fff3}.contact-card{background-color:#ffffff0a;border-width:1px;border-color:#ffffff1a;border-radius:1.75rem;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1);display:flex}.contact-card:hover{--tw-translate-y:-.25rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));background-color:#ffffff12;border-color:#67e8f933}.animate-fade-up{animation:.75s ease-out both fade-up}.reveal-delay-1{animation-delay:.12s}.reveal-delay-2{animation-delay:.2s}.reveal-delay-3{animation-delay:.28s}.reveal-delay-4{animation-delay:.36s}.reveal-delay-5{animation-delay:.44s}.reveal-delay-6{animation-delay:.52s}@keyframes fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.animate-fade-up{animation:none!important}}
