.portfolio{--bg:var(--portfolio-bg);--surface:var(--portfolio-surface);--surface2:var(--portfolio-surface2);--border:var(--portfolio-border);--accent:var(--portfolio-accent);--accent2:var(--portfolio-accent2);--accent3:var(--portfolio-accent3);--text:var(--portfolio-text);--muted:var(--portfolio-muted);--glow:var(--portfolio-glow);--nav-height:4.25rem;background:var(--bg);color:var(--text);font-family:var(--font-outfit),"Outfit",system-ui,sans-serif;font-weight:300;overflow-x:hidden;cursor:none;position:relative;min-height:100vh;display:flex;flex-direction:column}.portfolio .portfolio-main{flex:1;display:flex;flex-direction:column;width:100%;min-width:0}.portfolio *,.portfolio :after,.portfolio :before{box-sizing:border-box;margin:0;padding:0}html:has(.portfolio){scroll-behavior:smooth}.portfolio #cursor{width:12px;height:12px;background:var(--accent);border-radius:50%;z-index:9999;transition:transform .15s ease,background .2s;mix-blend-mode:var(--portfolio-cursor-blend)}.portfolio #cursor,.portfolio #cursor-ring{position:fixed;top:0;left:0;pointer-events:none}.portfolio #cursor-ring{width:36px;height:36px;border:1px solid rgba(0,212,255,.4);border-radius:50%;z-index:9998;transition:transform .35s cubic-bezier(.17,.67,.35,1.2)}.portfolio:before{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");z-index:9990;opacity:var(--portfolio-noise-opacity)}.portfolio:after,.portfolio:before{content:"";position:fixed;inset:0;pointer-events:none}.portfolio:after{background-image:linear-gradient(var(--portfolio-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--portfolio-grid-line) 1px,transparent 1px);background-size:60px 60px;z-index:0}.portfolio nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 3rem;backdrop-filter:blur(12px);background:var(--portfolio-nav-bg);border-bottom:.5px solid var(--portfolio-nav-border);transition:padding .3s,background-color .25s ease,border-color .25s ease}.portfolio nav.scrolled{padding:.9rem 3rem}.portfolio .site-logo{display:inline-flex;align-items:center;text-decoration:none;line-height:0;flex-shrink:0}.portfolio .site-logo-img{width:auto!important;height:auto;-o-object-fit:contain;object-fit:contain}.portfolio nav .site-logo-img{max-height:56px}.portfolio footer .site-logo-img{max-height:48px}.portfolio .nav-links{display:flex;gap:2rem;list-style:none}.portfolio .nav-links a{font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:13px;font-weight:400;color:var(--portfolio-nav-link);text-decoration:none;letter-spacing:.04em;transition:color .2s}.portfolio .nav-links a:hover{color:var(--text)}.portfolio .portfolio-nav__actions{display:flex;align-items:center;gap:1.25rem;margin-left:auto}.portfolio .portfolio-nav__theme-toggle{flex-shrink:0}.portfolio section{position:relative;z-index:1}.portfolio #about,.portfolio #contact,.portfolio #pricing,.portfolio #skills,.portfolio .projects-section,.portfolio .stats-bar,.portfolio footer{content-visibility:auto;contain-intrinsic-size:auto 600px}.portfolio #hero{position:relative;z-index:1;content-visibility:visible;contain-intrinsic-size:auto;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:0;padding-top:var(--nav-height);overflow:hidden;background:var(--portfolio-hero-bg)}.portfolio .hero-grid-bg{position:fixed;inset:0;background-image:linear-gradient(var(--portfolio-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--portfolio-grid-line) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}.portfolio .hero-grid-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 65% 50%,var(--portfolio-grid-glow) 0,transparent 70%)}.portfolio .hero-layout{position:relative;z-index:1;width:100%;max-width:1400px;margin:0 auto;min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:2rem;padding:0 3rem}.portfolio .hero-left{padding-top:2rem;padding-bottom:4rem}.portfolio .hero-tag-line{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:2rem;font-weight:500}.portfolio .hero-tag-line:before{content:"";display:block;width:24px;height:1px;background:var(--accent)}.portfolio .hero-headline-wrap{position:relative;min-height:200px;margin-bottom:1.75rem;overflow:hidden}.portfolio .hero-headline-wrap.hero-headline-wrap--css{overflow:visible}.portfolio .hero-headline-slide{position:absolute;top:0;left:0;width:100%;opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;pointer-events:none}.portfolio .hero-headline-slide.active{opacity:1;transform:translateY(0);pointer-events:auto;position:relative}.portfolio .hero-headline-slide.exit{opacity:0;transform:translateY(-24px);position:absolute}.portfolio .hero-headline-wrap--css{display:grid;grid-template-areas:"headline-stack";min-height:12rem;overflow:visible}.portfolio .hero-headline-wrap--css .hero-headline--slide-a,.portfolio .hero-headline-wrap--css .hero-headline--slide-b{grid-area:headline-stack;position:relative;width:100%;margin:0;padding-bottom:.12em;will-change:opacity,transform,visibility}.portfolio .hero-headline-wrap--css .hero-headline--slide-a{animation:hero-slide-a var(--hero-rotate,20s) ease-in-out infinite}.portfolio .hero-headline-wrap--css .hero-headline--slide-b{font-size:clamp(28px,3.15vw,47px);line-height:1.16;animation:hero-slide-b var(--hero-rotate,20s) ease-in-out infinite}.portfolio .hero-sub-wrap--css{display:grid;grid-template-areas:"sub-stack";min-height:5.5rem;margin-bottom:.5rem}.portfolio .hero-sub-wrap--css .hero-sub-text--slide-a,.portfolio .hero-sub-wrap--css .hero-sub-text--slide-b{grid-area:sub-stack;position:relative;width:100%;margin:0;min-height:auto}.portfolio .hero-sub-wrap--css .hero-sub-text--slide-a{animation:hero-sub-a var(--hero-rotate,20s) ease-in-out infinite}.portfolio .hero-sub-wrap--css .hero-sub-text--slide-b{animation:hero-sub-b var(--hero-rotate,20s) ease-in-out infinite}.portfolio .hero-progress-fill--css{width:0;animation:hero-progress-fill var(--hero-rotate,20s) linear infinite}.portfolio .hero-dots--css .hero-dot--a{animation:hero-dot-a var(--hero-rotate,20s) step-end infinite}.portfolio .hero-dots--css .hero-dot--b{animation:hero-dot-b var(--hero-rotate,20s) step-end infinite}@keyframes hero-slide-a{0%,47%{opacity:1;visibility:visible;z-index:2;transform:translateY(0);pointer-events:auto}48%,to{opacity:0;visibility:hidden;z-index:0;transform:translateY(-14px);pointer-events:none}}@keyframes hero-slide-b{0%,47%{opacity:0;visibility:hidden;z-index:0;transform:translateY(14px);pointer-events:none}48%,97%{opacity:1;visibility:visible;z-index:2;transform:translateY(0);pointer-events:auto}to{opacity:0;visibility:hidden;z-index:0;transform:translateY(14px);pointer-events:none}}@keyframes hero-sub-a{0%,47%{opacity:1;visibility:visible;z-index:2}48%,to{opacity:0;visibility:hidden;z-index:0}}@keyframes hero-sub-b{0%,47%{opacity:0;visibility:hidden;z-index:0}48%,97%{opacity:1;visibility:visible;z-index:2}to{opacity:0;visibility:hidden;z-index:0}}@keyframes hero-progress-fill{0%{width:0}90%{width:100%}to{width:0}}@keyframes hero-dot-a{0%,47%{background:var(--accent);width:24px;border-radius:3px;transform:scale(1)}48%,to{background:var(--portfolio-overlay-strong);width:6px;border-radius:50%;transform:scale(1)}}@keyframes hero-dot-b{0%,47%{background:var(--portfolio-overlay-strong);width:6px;border-radius:50%;transform:scale(1)}48%,97%{background:var(--accent);width:24px;border-radius:3px;transform:scale(1)}to{background:var(--portfolio-overlay-strong);width:6px;border-radius:50%;transform:scale(1)}}.portfolio .hero-headline-slide .hero-headline,.portfolio .hero-headline-slide h1,.portfolio .hero-headline-wrap--css .hero-headline{font-family:var(--font-syne),"Syne",system-ui,sans-serif;font-size:clamp(36px,4vw,54px);font-weight:800;line-height:1.08;letter-spacing:-.03em;color:var(--text);margin:0}.portfolio .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.portfolio .skills-seo-intro{max-width:720px;margin:0 auto 2rem;text-align:center;color:var(--portfolio-text-subtle);line-height:1.75;font-size:.95rem}.portfolio .project-case-study-link{display:inline-block;margin-top:.75rem;font-size:.82rem;color:var(--accent);text-decoration:none;font-family:var(--font-dm-mono),"DM Mono",monospace}.portfolio .project-case-study-link:hover{text-decoration:underline}.portfolio .seo-footer-links--desktop{display:none;margin:0}.portfolio .seo-footer-links{margin:0}.portfolio .seo-footer-links-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin:0 0 .65rem}.portfolio .seo-footer-links ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;justify-content:center}@media (min-width:1024px){.portfolio .seo-footer-links--desktop{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.portfolio .seo-footer-links--desktop ul{justify-content:flex-end}}.portfolio .seo-footer-links a{font-size:.82rem;color:var(--portfolio-text-subtle);text-decoration:none}.portfolio .hero-accent,.portfolio .seo-footer-links a:hover{color:var(--accent)}.portfolio .hero-strike{text-decoration:line-through;color:var(--portfolio-text-strike);opacity:.85;font-size:.75em}.portfolio .hero-sub-text{font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:15px;color:var(--portfolio-text-subtle);line-height:1.75;max-width:440px;margin-bottom:2.25rem;min-height:72px;transition:opacity .4s ease}.portfolio .hero-sub-text strong{color:var(--portfolio-text-strong);font-weight:600}.portfolio .hero-dots{display:flex;align-items:center;gap:8px;margin-bottom:2.25rem}.portfolio .hero-dot{width:6px;height:6px;border-radius:50%;background:var(--portfolio-overlay-strong);border:none;padding:0;cursor:none;transition:background .3s,width .3s}.portfolio .hero-dot.active{background:var(--accent);width:24px;border-radius:3px}.portfolio .hero-progress-bar{width:100%;max-width:440px;height:1px;background:var(--portfolio-progress-track);margin-bottom:2.25rem;border-radius:1px;overflow:hidden}.portfolio .hero-progress-fill{height:100%;background:var(--accent);width:0}.portfolio .hero-cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.portfolio .hero-btn-primary{background:var(--accent);color:var(--portfolio-on-accent);border:none;padding:13px 26px;border-radius:8px;font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:14px;font-weight:700;cursor:none;letter-spacing:.02em;text-decoration:none;transition:transform .15s,box-shadow .15s;display:inline-block}.portfolio .hero-btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px var(--portfolio-accent-shadow)}.portfolio .hero-btn-ghost{background:transparent;color:var(--text);border:.5px solid var(--portfolio-overlay-strong);padding:13px 26px;border-radius:8px;font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:14px;font-weight:400;cursor:none;text-decoration:none;transition:border-color .2s,background .2s;display:inline-block}.portfolio .hero-btn-ghost:hover{border-color:var(--portfolio-overlay-text);background:var(--portfolio-overlay-faint)}.portfolio .hero-price-badge{display:inline-flex;align-items:center;gap:6px;background:var(--portfolio-accent-soft);border:.5px solid var(--portfolio-accent-border);color:var(--accent);font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:12px;font-weight:500;padding:6px 14px;border-radius:100px;margin-top:1.5rem;letter-spacing:.04em}.portfolio .hero-price-badge:before{content:"●";font-size:8px;animation:hero-badge-pulse 1.5s infinite}@keyframes hero-badge-pulse{0%,to{opacity:1}50%{opacity:.3}}.portfolio .hero-right{display:flex;align-items:center;justify-content:center;padding-top:6rem;padding-bottom:4rem}.portfolio .hero-right-inner{position:relative;width:100%;max-width:480px}.portfolio .hero-code-ambient{position:absolute;inset:-12%;pointer-events:none;z-index:0;overflow:visible}.portfolio .hero-code-orb{position:absolute;border-radius:50%;filter:blur(52px);animation:hero-code-orb-pulse 9s ease-in-out infinite}.portfolio .hero-code-orb--cyan{width:160px;height:160px;top:5%;left:0;background:var(--portfolio-code-orb-cyan)}.portfolio .hero-code-orb--purple{width:130px;height:130px;bottom:8%;right:-5%;background:var(--portfolio-code-orb-purple);animation-delay:2s;animation-duration:11s}.portfolio .hero-code-orb--green{width:100px;height:100px;top:42%;right:15%;background:var(--portfolio-code-orb-green);animation-delay:1s;animation-duration:7s}@keyframes hero-code-orb-pulse{0%,to{transform:scale(1) translate(0);opacity:.5}50%{transform:scale(1.2) translate(6px,-10px);opacity:.85}}.portfolio .hero-code-wrap{position:relative;z-index:1;width:100%}.portfolio .hero-code-glow{position:absolute;inset:-3px;border-radius:16px;background:linear-gradient(120deg,var(--accent),var(--portfolio-accent2),var(--portfolio-accent3),var(--accent));background-size:280% 280%;animation:hero-code-border-glow 10s ease infinite;opacity:.65;z-index:0;filter:blur(8px);pointer-events:none}.portfolio .hero-code-window{position:relative;z-index:1;background:var(--portfolio-code-bg);border:1px solid var(--portfolio-code-border-accent);border-radius:14px;width:100%;overflow:hidden;box-shadow:var(--portfolio-code-shadow),0 0 32px color-mix(in srgb,var(--accent) 18%,transparent),0 0 64px color-mix(in srgb,var(--portfolio-accent2) 10%,transparent)}@keyframes hero-code-border-glow{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.portfolio .hero-window-bar{background:var(--portfolio-code-panel);padding:12px 16px;display:flex;align-items:center;gap:8px;border-bottom:.5px solid var(--portfolio-code-border)}.portfolio .hero-win-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.portfolio .hero-win-dot--r{background:#ff5f57}.portfolio .hero-win-dot--y{background:#febc2e}.portfolio .hero-win-dot--g{background:#28c840}.portfolio .hero-file-tab{margin-left:12px;display:inline-flex;align-items:center;gap:8px;font-size:11px;color:var(--portfolio-code-tab);letter-spacing:.04em}.portfolio .hero-file-tab-badge{font-size:9px;font-weight:700;letter-spacing:.06em;padding:2px 6px;border-radius:4px;background:linear-gradient(135deg,var(--accent),var(--portfolio-accent2));color:var(--portfolio-on-accent);line-height:1.2}.portfolio .hero-code-body{position:relative;padding:1.5rem;font-family:Courier New,Courier,monospace;font-size:12.5px;line-height:1.8;color:var(--portfolio-code-text);background:linear-gradient(165deg,color-mix(in srgb,var(--accent) 8%,var(--portfolio-code-bg)) 0,var(--portfolio-code-bg) 35%,color-mix(in srgb,var(--portfolio-accent2) 6%,var(--portfolio-code-bg)) 70%,color-mix(in srgb,var(--portfolio-accent3) 5%,var(--portfolio-code-bg)) 100%)}.portfolio .hero-code-body:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--accent),var(--portfolio-accent2),var(--portfolio-accent3));opacity:.85;border-radius:0 2px 2px 0}.portfolio .hero-code-body .c-kw{color:var(--portfolio-code-kw);font-weight:600}.portfolio .hero-code-body .c-fn{color:var(--portfolio-code-fn)}.portfolio .hero-code-body .c-str{color:var(--portfolio-code-str)}.portfolio .hero-code-body .c-num{color:var(--portfolio-code-num);font-weight:600}.portfolio .hero-code-body .c-cm{color:var(--portfolio-code-cm);font-style:italic}.portfolio .hero-code-body .c-var{color:var(--portfolio-code-var)}.portfolio .hero-code-body .c-bool{color:var(--portfolio-code-bool);font-weight:600}.portfolio .hero-code-body .c-bracket{color:var(--portfolio-code-bracket);opacity:.9}.portfolio .hero-code-body .c-op{color:var(--portfolio-code-op)}.portfolio .hero-terminal-bar{background:linear-gradient(90deg,color-mix(in srgb,var(--portfolio-accent3) 12%,var(--portfolio-code-panel)),var(--portfolio-code-panel));padding:10px 16px;border-top:.5px solid var(--portfolio-code-border);display:flex;align-items:center;gap:8px}.portfolio .hero-terminal-dot{width:6px;height:6px;border-radius:50%;background:#28c840;animation:hero-badge-pulse 1.5s infinite;flex-shrink:0}.portfolio .hero-terminal-text{font-family:Courier New,Courier,monospace;font-size:11px}.portfolio .hero-terminal-branch,.portfolio .hero-terminal-text{color:var(--portfolio-code-terminal)}.portfolio .hero-terminal-status{color:var(--portfolio-code-terminal-success);font-weight:600}.portfolio .hero-float-card{position:absolute;border-radius:10px;padding:10px 14px;font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:12px;color:var(--portfolio-float-card-text);display:flex;align-items:center;gap:8px;z-index:2;animation:hero-float-up 3s ease-in-out infinite;backdrop-filter:blur(8px)}.portfolio .hero-float-card--cyan{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%,var(--portfolio-surface)),var(--portfolio-surface));border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);box-shadow:0 8px 28px color-mix(in srgb,var(--accent) 22%,transparent),0 0 0 1px color-mix(in srgb,var(--accent) 15%,transparent) inset}.portfolio .hero-float-card--green{background:linear-gradient(135deg,color-mix(in srgb,var(--portfolio-accent3) 18%,var(--portfolio-surface)),var(--portfolio-surface));border:1px solid color-mix(in srgb,var(--portfolio-accent3) 45%,transparent);box-shadow:0 8px 28px color-mix(in srgb,var(--portfolio-accent3) 20%,transparent),0 0 0 1px color-mix(in srgb,var(--portfolio-accent3) 12%,transparent) inset}.portfolio .hero-float-card--bottom{bottom:22%;right:-20px;animation-delay:0s}.portfolio .hero-float-card--top{top:22%;left:-20px;animation-delay:1.5s}@keyframes hero-float-up{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.portfolio .hero-float-icon{font-size:16px}.portfolio .hero-scroll-hint{position:fixed;bottom:2rem;left:3rem;display:flex;align-items:center;gap:10px;font-family:var(--font-dm-sans),"DM Sans",var(--font-outfit),system-ui,sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--portfolio-scroll-hint);z-index:10}.portfolio .hero-scroll-line{width:32px;height:.5px;background:var(--portfolio-overlay-strong)}.portfolio .btn-primary{padding:14px 32px;background:var(--accent);color:var(--bg);font-family:var(--font-syne),"Syne",sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.06em;border:none;border-radius:4px;cursor:none;text-decoration:none;transition:box-shadow .3s,transform .2s;display:inline-block}.portfolio .btn-primary:hover{box-shadow:0 0 30px rgba(0,212,255,.4);transform:translateY(-2px)}.portfolio .btn-outline{padding:14px 32px;background:transparent;color:var(--text);font-family:var(--font-syne),"Syne",sans-serif;font-weight:600;font-size:.85rem;letter-spacing:.06em;border:1px solid var(--border);border-radius:4px;cursor:none;text-decoration:none;transition:border-color .3s,color .3s;display:inline-block}.portfolio .btn-outline:hover{border-color:var(--accent);color:var(--accent)}.portfolio .hero-photo-wrap{position:relative;opacity:0;animation:fadeIn 1s .9s forwards;width:min(460px,46vw);height:min(460px,46vw);margin-left:auto}.portfolio .hero-float-scene{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.portfolio .hero-float-ambient{position:absolute;inset:0;pointer-events:none;overflow:visible;z-index:0}.portfolio .hero-float-orb{position:absolute;border-radius:50%;filter:blur(48px);opacity:.45;animation:orb-pulse 8s ease-in-out infinite}.portfolio .hero-float-orb-1{width:140px;height:140px;top:8%;left:12%;background:var(--portfolio-accent-glow);animation-delay:0s}.portfolio .hero-float-orb-2{width:120px;height:120px;bottom:10%;right:8%;background:var(--portfolio-purple-soft);animation-delay:2.5s;animation-duration:10s}.portfolio .hero-float-orb-3{width:90px;height:90px;top:45%;right:20%;background:var(--portfolio-accent-soft);animation-delay:1.2s;animation-duration:7s}@keyframes orb-pulse{0%,to{transform:scale(1) translate(0);opacity:.35}50%{transform:scale(1.15) translate(8px,-12px);opacity:.55}}.portfolio .hero-float-logo{position:absolute;animation-duration:var(--float-duration,6s);animation-delay:var(--float-delay,0s);animation-timing-function:ease-in-out;animation-iteration-count:infinite;will-change:transform}.portfolio .hero-float-logo.anim-drift-a{animation-name:float-drift-a}.portfolio .hero-float-logo.anim-drift-b{animation-name:float-drift-b}.portfolio .hero-float-logo.anim-drift-c{animation-name:float-drift-c}.portfolio .hero-float-logo.anim-drift-d{animation-name:float-drift-d}.portfolio .hero-float-logo.anim-drift-e{animation-name:float-drift-e}.portfolio .hero-float-logo-glow{position:absolute;inset:-8px;border-radius:16px;background:radial-gradient(circle at 50% 50%,rgba(0,212,255,.15) 0,transparent 70%);opacity:0;transition:opacity .35s;pointer-events:none}.portfolio .hero-float-logo:hover .hero-float-logo-glow{opacity:1}.portfolio .hero-float-logo-inner{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:14px;background:linear-gradient(145deg,var(--portfolio-float-logo-bg-start) 0,var(--portfolio-float-logo-bg-end) 100%);border:1px solid var(--portfolio-float-logo-border);backdrop-filter:blur(10px);box-shadow:0 10px 28px rgba(0,0,0,.45),0 0 0 1px var(--portfolio-card-inset) inset,0 0 24px rgba(0,212,255,.06);transition:border-color .3s,box-shadow .3s,transform .3s}.portfolio .hero-float-logo:hover .hero-float-logo-inner{border-color:rgba(0,212,255,.55);box-shadow:0 14px 36px rgba(0,0,0,.5),0 0 32px rgba(0,212,255,.22);transform:scale(1.1) rotate(-2deg)}.portfolio .hero-float-logo-img{width:calc(100% - 14px);height:calc(100% - 14px);-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}@keyframes float-drift-a{0%,to{transform:translate(0) rotate(0deg)}25%{transform:translate(14px,-18px) rotate(4deg)}50%{transform:translate(-6px,-28px) rotate(-2deg)}75%{transform:translate(-12px,-10px) rotate(3deg)}}@keyframes float-drift-b{0%,to{transform:translate(0) rotate(0deg)}33%{transform:translate(-16px,12px) rotate(-5deg)}66%{transform:translate(10px,-20px) rotate(4deg)}}@keyframes float-drift-c{0%,to{transform:translate(0) scale(1)}20%{transform:translate(8px,-14px) scale(1.03)}45%{transform:translate(-14px,-8px) scale(.98)}70%{transform:translate(12px,10px) scale(1.02)}}@keyframes float-drift-d{0%,to{transform:translate(0) rotate(0deg)}40%{transform:translate(18px,8px) rotate(6deg)}80%{transform:translate(-10px,-16px) rotate(-4deg)}}@keyframes float-drift-e{0%,to{transform:translate(0)}30%{transform:translate(-8px,-22px)}60%{transform:translate(16px,-6px)}85%{transform:translate(-4px,14px)}}.portfolio .hero-photo-frame{position:relative;z-index:10;width:280px;height:340px;border-radius:12px;background:var(--surface2);border:1px solid var(--border);overflow:hidden;box-shadow:0 24px 48px rgba(0,0,0,.5),0 0 40px rgba(0,212,255,.1)}.portfolio .hero-photo-frame:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,212,255,.05),rgba(124,58,237,.05))}.portfolio .hero-profile-img{-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top}.portfolio .hero-photo-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,212,255,.08),transparent 40%,transparent 60%,rgba(124,58,237,.08));pointer-events:none;z-index:1}.portfolio .photo-corner{position:absolute;width:20px;height:20px;border-color:var(--accent);border-style:solid;border-width:0}.portfolio .photo-corner.tl{top:-1px;left:-1px;border-top-width:2px;border-left-width:2px}.portfolio .photo-corner.tr{top:-1px;right:-1px;border-top-width:2px;border-right-width:2px}.portfolio .photo-corner.bl{bottom:-1px;left:-1px;border-bottom-width:2px;border-left-width:2px}.portfolio .photo-corner.br{bottom:-1px;right:-1px;border-bottom-width:2px;border-right-width:2px}.portfolio .hero-photo-frame-deco{position:absolute;bottom:8px;right:-12px;width:280px;height:340px;border:1px solid var(--border);border-radius:12px;z-index:0}.portfolio .scroll-down{position:absolute;bottom:40px;left:60px;display:flex;align-items:center;gap:12px;font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.7rem;color:var(--muted);letter-spacing:.1em;opacity:0;animation:fadeUp .7s 1.1s forwards}.portfolio .scroll-line{width:50px;height:1px;background:linear-gradient(to right,var(--muted),transparent);position:relative;overflow:hidden}.portfolio .scroll-line:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--accent);animation:slide-line 2s ease infinite}@keyframes slide-line{to{left:200%}}.portfolio .stats-bar{padding:30px 60px;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;gap:0;position:relative;z-index:1}.portfolio .stat-item{flex:1;text-align:center;padding:16px 0;border-right:1px solid var(--border);opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}.portfolio .stat-item:last-child{border-right:none}.portfolio .stat-item.visible{opacity:1;transform:translateY(0)}.portfolio .stat-num{font-family:var(--font-syne),"Syne",sans-serif;font-size:2.2rem;font-weight:800;color:var(--accent);line-height:1}.portfolio .stat-label{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.7rem;color:var(--muted);letter-spacing:.1em;margin-top:6px;text-transform:uppercase}.portfolio #about{padding:120px 60px;max-width:1200px;margin:0 auto}.portfolio .section-label{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.72rem;color:var(--accent);letter-spacing:.25em;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:12px}.portfolio .section-label:before{content:"";width:30px;height:1px;background:var(--accent)}.portfolio .section-title{font-family:var(--font-syne),"Syne",sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:60px;line-height:1.1}.portfolio .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.portfolio .about-photo-col{display:flex;justify-content:flex-end}.portfolio .about-grid .hero-photo-wrap{opacity:1;animation:none;margin-left:0;margin-right:0}.portfolio .about-text p{color:var(--portfolio-text-subtle);line-height:1.9;margin-bottom:20px;font-size:.98rem}.portfolio #pricing{padding:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--portfolio-bg) 0,var(--portfolio-pricing-gradient-mid) 45%,var(--portfolio-bg) 100%)}.portfolio .pricing-inner{max-width:1200px;margin:0 auto;padding:100px 48px 110px}.portfolio .pricing-header{margin-bottom:52px}.portfolio .pricing-header>.section-label{justify-content:flex-start;margin-bottom:28px}.portfolio .pricing-header-center{text-align:center}.portfolio .pricing-header-center .section-title{font-size:clamp(2rem,4.5vw,2.75rem);letter-spacing:-.02em;line-height:1.15;margin-bottom:18px}.portfolio .pricing-subtitle{color:var(--muted);font-size:1rem;line-height:1.65;max-width:52ch;margin:0 auto}.portfolio .pricing-lanes{display:flex;flex-direction:column;gap:28px}.portfolio .pricing-grid{display:grid;gap:24px;align-items:stretch}.portfolio .pricing-grid--featured,.portfolio .pricing-grid--primary{grid-template-columns:repeat(3,minmax(0,1fr))}.portfolio .pricing-grid--featured{max-width:1200px;margin:0 auto;width:100%}.portfolio .pricing-card{position:relative;display:flex;flex-direction:column;min-height:100%;padding:28px 26px 26px;background:var(--surface);border:1px solid var(--border);border-radius:14px;opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease,border-color .3s ease,box-shadow .3s ease;cursor:default}.portfolio .pricing-card.visible{opacity:1;transform:translateY(0)}.portfolio .pricing-card:hover{border-color:rgba(0,212,255,.28);box-shadow:0 16px 48px rgba(0,0,0,.35)}.portfolio .pricing-card--popular{border-color:rgba(0,212,255,.45);background:linear-gradient(165deg,rgba(0,212,255,.08) 0,var(--surface) 42%,var(--surface) 100%);box-shadow:0 0 0 1px rgba(0,212,255,.12),0 20px 50px rgba(0,0,0,.4)}.portfolio .pricing-card--popular:hover{border-color:rgba(0,212,255,.6);box-shadow:0 0 0 1px rgba(0,212,255,.2),0 24px 56px rgba(0,212,255,.12)}.portfolio .pricing-card-badge{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);padding:6px 14px;border-radius:999px;font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:linear-gradient(90deg,var(--accent),var(--accent2));white-space:nowrap;z-index:2}.portfolio .pricing-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.portfolio .pricing-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex-shrink:0;border-radius:12px;border:1px solid var(--border);background:var(--surface2);font-size:1.35rem;line-height:1}.portfolio .pricing-card-price{text-align:right;flex-shrink:0}.portfolio .pricing-card-price-note{display:block;font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}.portfolio .pricing-card-price-value{display:block;font-family:var(--font-syne),"Syne",sans-serif;font-size:1.65rem;font-weight:800;line-height:1.1;color:var(--text);white-space:nowrap}.portfolio .pricing-card--popular .pricing-card-price-value{color:var(--accent)}.portfolio .pricing-card-title{font-family:var(--font-syne),"Syne",sans-serif;font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.25}.portfolio .pricing-card-tagline{font-size:.88rem;line-height:1.5;color:var(--muted);margin-bottom:22px;padding-bottom:20px;border-bottom:1px solid var(--border)}.portfolio .pricing-card-block{margin-bottom:18px}.portfolio .pricing-card-block--grow{flex:1;margin-bottom:20px}.portfolio .pricing-card-block-label{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.portfolio .pricing-card-list{list-style:none;display:flex;flex-direction:column;gap:8px}.portfolio .pricing-card-list li{position:relative;padding-left:16px;font-size:.86rem;line-height:1.45;color:var(--text);opacity:.92}.portfolio .pricing-card-list li:before{position:absolute;left:0;top:.45em;font-size:.55rem;line-height:1;color:var(--accent);content:"◆"}.portfolio .pricing-card-list--checks li:before{content:"✓";color:var(--accent3);font-size:.7rem;top:.35em}.portfolio .pricing-card-tiers{margin-bottom:20px}.portfolio .pricing-card-tier{padding:14px 16px;margin-bottom:12px;border-radius:10px;border:1px solid var(--border);background:var(--portfolio-shadow)}.portfolio .pricing-card-tier:last-child{margin-bottom:0}.portfolio .pricing-card--popular .pricing-card-tier:last-child{border-color:rgba(0,212,255,.25);background:var(--portfolio-accent-soft)}.portfolio .pricing-card-tier-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.portfolio .pricing-card-tier-title{font-family:var(--font-syne),"Syne",sans-serif;font-size:.92rem;font-weight:700;color:var(--text);line-height:1.3;flex:1}.portfolio .pricing-card-tier-price{text-align:right;flex-shrink:0}.portfolio .pricing-card-tier-price-value{display:block;font-family:var(--font-syne),"Syne",sans-serif;font-size:1.2rem;font-weight:800;line-height:1.1;color:var(--accent)}.portfolio .pricing-card-tier-label{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.portfolio .pricing-card-tier .pricing-card-list{gap:6px}.portfolio .pricing-card-tier .pricing-card-list li{font-size:.8rem}.portfolio .pricing-card-tech{margin-bottom:20px;padding:12px 14px;border-radius:10px;border:1px dashed var(--border);background:var(--portfolio-card-shadow)}.portfolio .pricing-card-tech-value{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.78rem;line-height:1.5;color:var(--text);opacity:.9}.portfolio .pricing-card-extras{margin-bottom:22px;padding:14px 16px;border-radius:10px;border:1px solid var(--border);background:var(--portfolio-shadow)}.portfolio .pricing-card-extras .pricing-card-block-label{color:rgba(124,58,237,.95);margin-bottom:8px}.portfolio .pricing-card-extras-list{list-style:none;display:flex;flex-direction:column;gap:6px}.portfolio .pricing-card-extras-list li{font-size:.8rem;line-height:1.45;color:var(--muted);padding-left:0}.portfolio .pricing-card-extras-list li:before{content:none}.portfolio .pricing-card-cta{display:block;width:100%;margin-top:auto;text-align:center;text-decoration:none;box-sizing:border-box}.portfolio .pricing-card--popular .pricing-card-cta{margin-top:auto}.portfolio .pricing-footnote{margin-top:36px;text-align:center;font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.75rem;letter-spacing:.04em;color:var(--muted)}.portfolio .pricing-footnote a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}.portfolio .pricing-footnote a:hover{border-bottom-color:var(--accent)}.portfolio #skills{padding:120px 60px;max-width:1200px;margin:0 auto}.portfolio .skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.portfolio .skill-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:28px;position:relative;overflow:hidden;opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s,border-color .3s;cursor:default}.portfolio .skill-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(0,212,255,.04),transparent 60%);opacity:0;transition:opacity .3s}.portfolio .skill-card:hover{border-color:rgba(0,212,255,.3)}.portfolio .skill-card:hover:before{opacity:1}.portfolio .skill-card.visible{opacity:1;transform:translateY(0)}.portfolio .skill-card-icon{width:40px;height:40px;border-radius:8px;background:var(--surface2);display:flex;align-items:center;justify-content:center;margin-bottom:14px;font-size:1.2rem}.portfolio .skill-card-title{font-family:var(--font-syne),"Syne",sans-serif;font-weight:700;font-size:.95rem;margin-bottom:10px;color:var(--text)}.portfolio .skill-tags{display:flex;flex-wrap:wrap;gap:6px}.portfolio .skill-tag{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.7rem;padding:4px 10px;border-radius:3px;background:var(--surface2);color:var(--muted);border:1px solid var(--border);letter-spacing:.03em}.portfolio #education{padding:120px 60px;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.portfolio .edu-inner{max-width:1200px;margin:0 auto}.portfolio .edu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.portfolio .edu-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:32px;position:relative;overflow:hidden;opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}.portfolio .edu-card.visible{opacity:1;transform:translateY(0)}.portfolio .edu-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.portfolio .edu-degree{font-family:var(--font-syne),"Syne",sans-serif;font-weight:700;font-size:1rem;line-height:1.3}.portfolio .edu-gpa{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.75rem;color:var(--accent3);background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);border-radius:4px;padding:4px 10px;white-space:nowrap}.portfolio .edu-school{font-size:.85rem;color:var(--muted);margin-bottom:4px}.portfolio .edu-year{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.7rem;color:var(--accent)}.portfolio .projects-section{padding:120px 0;max-width:100%;overflow:hidden;text-align:center}.portfolio .projects-section .section-label{max-width:1200px;margin-left:auto;margin-right:auto;margin-bottom:10px;padding:0 60px}.portfolio .projects-section .section-title{max-width:1200px;margin-left:auto;margin-right:auto;margin-bottom:12px;padding:0 60px}.portfolio .projects-header{max-width:1200px;margin:0 auto 8px;padding:0 60px}.portfolio .projects-header .section-label,.portfolio .projects-header .section-title{padding:0}.portfolio .projects-sub{color:var(--muted);font-size:.98rem;margin:0;max-width:520px;padding:0}.portfolio .projects-section .curved-carousel-mask{padding:0}.portfolio .projects-section .curved-carousel-track{padding-top:16px;padding-bottom:48px}.portfolio .dev-carousel{position:relative;width:100%;--active-accent:var(--accent)}.portfolio .dev-carousel-ambient{position:absolute;top:50%;left:50%;width:min(900px,90vw);height:420px;transform:translate(-50%,-55%);background:radial-gradient(ellipse at center,color-mix(in srgb,var(--active-accent) 22%,transparent) 0,transparent 70%);filter:blur(60px);pointer-events:none;z-index:0;transition:background .6s ease}.portfolio .dev-carousel-frame{position:relative;z-index:1;display:flex;align-items:center;gap:12px;padding:0 16px}.portfolio .carousel-nav-btn{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:color-mix(in srgb,var(--portfolio-surface) 85%,transparent);backdrop-filter:blur(12px);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:none;transition:border-color .25s,color .25s,box-shadow .25s,transform .2s;z-index:10}.portfolio .carousel-nav-btn svg{width:20px;height:20px}.portfolio .carousel-nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);box-shadow:0 0 24px rgba(0,212,255,.2);transform:scale(1.05)}.portfolio .carousel-nav-btn:disabled{opacity:.25;cursor:not-allowed}.portfolio .curved-carousel-mask{flex:1;min-width:0;padding:20px 0;mask-image:radial-gradient(ellipse 95% 82% at 50% 45%,#000 45%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 95% 82% at 50% 45%,#000 45%,transparent 100%)}.portfolio .curved-carousel-scene{perspective:1600px;perspective-origin:50% 42%;transform-style:preserve-3d}.portfolio .curved-carousel-track{display:flex;gap:28px;overflow-x:auto;overflow-y:hidden;padding:56px 12vw 64px;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;transform-style:preserve-3d;-webkit-overflow-scrolling:touch}.portfolio .curved-carousel-track::-webkit-scrollbar{display:none}.portfolio .project-slide{position:relative;flex:0 0 clamp(300px,42vw,460px);scroll-snap-align:center;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .4s ease;will-change:transform,opacity;cursor:grab}.portfolio .project-slide:active{cursor:grabbing}.portfolio .project-slide-glow{position:absolute;inset:-20px;background:radial-gradient(circle at 50% 60%,color-mix(in srgb,var(--slide-accent) 35%,transparent),transparent 65%);opacity:0;filter:blur(28px);transition:opacity .45s ease;pointer-events:none;z-index:0}.portfolio .project-slide.is-active .project-slide-glow{opacity:1}.portfolio .project-slide-inner{position:relative;z-index:1;border-radius:14px;overflow:hidden;background:var(--portfolio-section-deep);border:1px solid var(--border);box-shadow:0 32px 64px rgba(0,0,0,.55);transform-style:preserve-3d;backface-visibility:hidden;transition:border-color .4s ease,box-shadow .4s ease}.portfolio .project-slide.is-active .project-slide-inner{border-color:color-mix(in srgb,var(--slide-accent) 55%,var(--border));box-shadow:0 32px 64px rgba(0,0,0,.55),0 0 0 1px color-mix(in srgb,var(--slide-accent) 30%,transparent),0 0 48px color-mix(in srgb,var(--slide-accent) 18%,transparent)}.portfolio .project-slide-inner:after{content:"";position:absolute;inset:0;border-radius:14px;padding:1px;background:linear-gradient(135deg,color-mix(in srgb,var(--slide-accent) 80%,transparent),transparent 40%,transparent 60%,color-mix(in srgb,var(--slide-accent) 40%,transparent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;-webkit-mask-composite:xor;pointer-events:none;opacity:0;transition:opacity .4s ease;z-index:5}.portfolio .project-slide.is-active .project-slide-inner:after{opacity:1}.portfolio .project-chrome{display:flex;align-items:center;gap:12px;padding:10px 14px;background:linear-gradient(180deg,var(--portfolio-chrome-gradient-start) 0,var(--portfolio-chrome-gradient-end) 100%);border-bottom:1px solid var(--border)}.portfolio .project-chrome-dots{display:flex;gap:6px}.portfolio .project-chrome-dots .dot{width:10px;height:10px;border-radius:50%}.portfolio .project-chrome-dots .red{background:#ff5f57}.portfolio .project-chrome-dots .yellow{background:#febc2e}.portfolio .project-chrome-dots .green{background:#28c840}.portfolio .project-chrome-url{flex:1;display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.68rem;color:var(--muted);overflow:hidden}.portfolio .project-chrome-url code{color:var(--slide-accent,var(--accent));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portfolio .project-chrome-lock{font-size:.6rem;opacity:.7}.portfolio .project-chrome-index{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.65rem;color:var(--muted);letter-spacing:.1em}.portfolio .project-slide-viewport{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--portfolio-footer-bg)}.portfolio .project-slide-img{-o-object-position:top center;object-position:top center;-o-object-fit:cover;object-fit:cover;transition:transform .6s cubic-bezier(.22,1,.36,1);filter:saturate(.85) contrast(1.05)}.portfolio .project-slide.is-active .project-slide-img{filter:saturate(1) contrast(1.08)}.portfolio .project-slide:hover .project-slide-img{transform:scale(1.05)}.portfolio .project-slide-scanlines{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.12) 0,rgba(0,0,0,.12) 4px);pointer-events:none;z-index:2;opacity:.4}.portfolio .project-slide-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,212,255,.04) 1px,transparent 0),linear-gradient(90deg,rgba(0,212,255,.04) 1px,transparent 0);background-size:24px 24px;pointer-events:none;z-index:2;opacity:.5}.portfolio .project-slide-glare{position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(105deg,transparent 40%,var(--portfolio-glare) 50%,transparent 60%);z-index:3;pointer-events:none;animation:project-glare 4s ease-in-out infinite}.portfolio .project-slide.is-active .project-slide-glare{animation-duration:3s}@keyframes project-glare{0%{left:-100%}45%,to{left:150%}}.portfolio .project-slide-body{padding:16px 18px 14px;background:linear-gradient(180deg,var(--portfolio-slide-body-start) 0,var(--portfolio-slide-body-end) 100%);text-align:left}.portfolio .project-slide-stack{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.portfolio .project-stack-tag{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.62rem;padding:3px 8px;border-radius:4px;background:color-mix(in srgb,var(--slide-accent) 12%,var(--surface2));border:1px solid color-mix(in srgb,var(--slide-accent) 35%,var(--border));color:var(--slide-accent,var(--accent));letter-spacing:.04em}.portfolio .project-slide-category{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.65rem;color:var(--muted);letter-spacing:.14em;text-transform:uppercase}.portfolio .project-slide-title{font-family:var(--font-syne),"Syne",sans-serif;font-size:1.35rem;font-weight:800;margin:4px 0 8px;color:var(--text)}.portfolio .project-slide-desc{font-size:.82rem;color:var(--portfolio-text-subtle);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portfolio .project-slide-terminal{display:flex;align-items:center;gap:14px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.65rem;color:var(--muted);flex-wrap:wrap}.portfolio .project-terminal-prompt{color:var(--slide-accent,var(--accent));margin-right:4px}.portfolio .project-terminal-branch{color:var(--text)}.portfolio .project-terminal-status{display:flex;align-items:center;gap:6px;color:var(--accent3)}.portfolio .project-terminal-status .status-dot{width:6px;height:6px;border-radius:50%;background:var(--accent3);box-shadow:0 0 8px var(--accent3);animation:status-pulse 2s ease infinite}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.4}}.portfolio .project-terminal-env{margin-left:auto;padding:2px 8px;border-radius:3px;background:var(--portfolio-accent-soft);border:1px solid rgba(0,212,255,.2);color:var(--accent);text-transform:uppercase;letter-spacing:.08em}.portfolio .dev-carousel-footer{position:relative;z-index:2;margin-top:8px;padding:0 24px}.portfolio .curved-carousel-hint{display:flex;align-items:center;justify-content:center;gap:12px;font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:20px}.portfolio .curved-carousel-hint-keys{padding:4px 10px;border-radius:4px;border:1px solid var(--border);background:var(--surface);color:var(--accent);font-size:.65rem}.portfolio .dev-carousel-tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;max-width:900px;margin:0 auto}.portfolio .dev-carousel-tab{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.72rem;padding:8px 16px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:none;transition:color .25s,border-color .25s,background .25s,box-shadow .25s}.portfolio .dev-tab-prefix{color:var(--accent2);margin-right:2px}.portfolio .dev-carousel-tab:hover{border-color:var(--accent);color:var(--text)}.portfolio .dev-carousel-tab.active{color:var(--accent);border-color:var(--accent);background:var(--portfolio-accent-soft);box-shadow:0 0 20px rgba(0,212,255,.15)}.portfolio #contact{padding:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--portfolio-bg) 0,var(--portfolio-pricing-gradient-mid) 45%,var(--portfolio-bg) 100%)}.portfolio .contact-inner{max-width:1200px;margin:0 auto;padding:100px 48px 110px;text-align:center}.portfolio .contact-header{margin-bottom:48px}.portfolio .contact-header .section-label{justify-content:center;margin-bottom:14px}.portfolio .contact-header .section-title{font-size:clamp(2rem,4.5vw,2.75rem);letter-spacing:-.02em;line-height:1.15;margin-bottom:18px}.portfolio .section-label.center{justify-content:center}.portfolio .contact-title-accent{color:var(--accent)}.portfolio .contact-sub{color:var(--muted);font-size:1rem;line-height:1.65;max-width:52ch;margin:0 auto}.portfolio .contact-form-wrapper{max-width:560px;margin:0 auto;text-align:left}.portfolio .contact-form{display:flex;flex-direction:column;gap:20px}.portfolio .contact-field{display:flex;flex-direction:column;gap:8px}.portfolio .contact-label{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.72rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}.portfolio .contact-required{color:var(--accent);margin-left:4px}.portfolio .contact-optional{font-size:.65rem;color:var(--muted);text-transform:none;letter-spacing:0;margin-left:6px;opacity:.8}.portfolio .contact-input{width:100%;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font-outfit),"Outfit",sans-serif;font-size:.92rem;transition:border-color .2s,box-shadow .2s}.portfolio .contact-input::-moz-placeholder{color:var(--muted);opacity:.7}.portfolio .contact-input::placeholder{color:var(--muted);opacity:.7}.portfolio .contact-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,212,255,.12)}.portfolio .contact-input-error{border-color:var(--portfolio-error)}.portfolio .contact-textarea{resize:vertical;min-height:120px}.portfolio .contact-select{cursor:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23475569' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}.dark .portfolio .contact-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235a7080' d='M1 1l5 5 5-5'/%3E%3C/svg%3E")}.portfolio .contact-select option{background:var(--surface2);color:var(--text)}.portfolio .contact-form-loading{min-height:320px}.portfolio .contact-field-error{font-size:.78rem;color:var(--portfolio-error)}.portfolio .contact-form-status{font-size:.88rem;padding:12px 14px;border-radius:6px;text-align:center}.portfolio .contact-form-status-success{color:var(--accent3);background:var(--portfolio-success-soft);border:1px solid var(--portfolio-success-border)}.portfolio .contact-form-status-error{color:var(--portfolio-error);background:var(--portfolio-error-soft);border:1px solid var(--portfolio-error-border)}.portfolio .contact-submit{width:100%;margin-top:4px;cursor:none}.portfolio .contact-submit:disabled{opacity:.6;cursor:not-allowed}.portfolio footer{border-top:1px solid var(--border);padding:28px 60px;display:flex;flex-direction:column;gap:1.25rem;justify-content:center;align-items:center;text-align:center;background:var(--surface);position:relative;z-index:1;margin-top:auto;flex-shrink:0}.portfolio .footer-badge,.portfolio .footer-copy{font-family:var(--font-dm-mono),"DM Mono",monospace;font-size:.7rem;color:var(--muted)}.portfolio .footer-badge{display:flex;align-items:center;gap:6px}.portfolio .footer-badge span{color:var(--accent)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.portfolio .particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.portfolio .particle{position:absolute;width:2px;height:2px;border-radius:50%;background:var(--accent);opacity:0;animation:float-particle linear infinite}@keyframes float-particle{0%{transform:translateY(100vh) translateX(0);opacity:0}10%{opacity:.4}90%{opacity:.1}to{transform:translateY(-10vh) translateX(var(--drift));opacity:0}}.portfolio .reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.portfolio .reveal.visible{opacity:1;transform:translateY(0)}