@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500;700&display=swap);*{box-sizing:border-box}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}a{text-decoration:none!important}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,sans-serif;font-family:var(--font-heading,"Space Grotesk",sans-serif)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--bg:#050d18;--bg-2:#070f1e;--bg-alt:#080e1c;--surface:#0a1628e0;--surface-2:#0e1c32eb;--surface-soft:#ffffff0a;--text-1:#e8f0f7;--text-2:#7e9ab5;--text-3:#4e6a82;--accent-hue:160;--accent:hsl(var(--accent-hue),84%,45%);--accent-dim:hsla(var(--accent-hue),84%,45%,0.14);--accent-border:hsla(var(--accent-hue),84%,45%,0.35);--warm:#f97316;--warm-dim:#f973161f;--border:#ffffff14;--border-2:#ffffff0d;--shadow:0 20px 60px #00000073;--shadow-sm:0 8px 24px #00000047;--radius:12px;--radius-sm:calc(var(--radius)*0.66);--radius-pill:999px;--font-heading:"Space Grotesk",sans-serif}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#070f1e;background:var(--bg-2)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#12d393,#059669);background:linear-gradient(180deg,var(--accent),#059669);border-radius:999px;border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:#34d399}button:focus{box-shadow:none!important;outline:none}button:focus-visible{outline:2px solid #12d393;outline:2px solid var(--accent);outline-offset:2px}#preloader{align-items:center;background:#050d18;background:var(--bg);display:flex;inset:0;justify-content:center;position:fixed;z-index:999999}#preloader:after{animation:spin .65s linear infinite;border:2px solid #10b9812e;border-radius:50%;border-top:2px solid var(--accent);content:"";height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}#preloader-none{opacity:0;pointer-events:none;transition:opacity .5s ease}#no-scroll{height:100vh;overflow:hidden}.portfolio-nav{align-items:center;display:flex;height:68px;left:0;padding:0 2.5rem;position:fixed;right:0;top:0;transition:background .35s ease,box-shadow .35s ease,-webkit-backdrop-filter .35s ease;transition:background .35s ease,box-shadow .35s ease,backdrop-filter .35s ease;transition:background .35s ease,box-shadow .35s ease,backdrop-filter .35s ease,-webkit-backdrop-filter .35s ease;z-index:1000}.portfolio-nav.scrolled{backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:#050d18e6;box-shadow:0 1px 0 #ffffff14,0 8px 24px #0003;box-shadow:0 1px 0 var(--border),0 8px 24px #0003}.nav-brand{align-items:center;color:#e8f0f7;color:var(--text-1);display:flex;flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:700;gap:.6rem;letter-spacing:.08em;text-decoration:none!important}.nav-brand-dot{animation:pulse-dot 2.4s ease-in-out infinite;background:#12d393;background:var(--accent);border-radius:50%;box-shadow:0 0 8px #10b98180;height:8px;width:8px}@keyframes pulse-dot{0%,to{box-shadow:0 0 8px #10b98180;opacity:1;transform:scale(1)}50%{box-shadow:0 0 4px #10b98133;opacity:.6;transform:scale(.85)}}.nav-links{align-items:center;display:flex;gap:.15rem;list-style:none;margin-bottom:0;margin-left:auto;padding:0}.nav-links li a,.nav-links li button{background:none;border:none;border-radius:7.92px;border-radius:var(--radius-sm);color:#7e9ab5;color:var(--text-2);cursor:pointer;display:inline-block;font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;letter-spacing:.01em;padding:.42rem .9rem;transition:color .2s ease,background .2s ease}.nav-links li a.active,.nav-links li a:hover,.nav-links li button.active,.nav-links li button:hover{background:#ffffff0d;color:#e8f0f7;color:var(--text-1)}.nav-links li button.active{color:#12d393;color:var(--accent)}.nav-cta-link{background:#12d39324!important;background:var(--accent-dim)!important;border:1px solid #12d39359!important;border:1px solid var(--accent-border)!important;border-radius:7.92px!important;border-radius:var(--radius-sm)!important;font-weight:600!important;padding:.4rem 1rem!important;transition:background .2s ease,transform .15s ease!important}.nav-cta-link,.nav-cta-link:hover{color:#12d393!important;color:var(--accent)!important}.nav-cta-link:hover{background:#10b98138!important;transform:translateY(-1px)}.nav-hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;margin-left:auto;padding:.5rem}.nav-hamburger span{background:#7e9ab5;background:var(--text-2);border-radius:999px;border-radius:var(--radius-pill);display:block;height:2px;transition:.3s ease;width:22px}.nav-hamburger:hover span{background:#e8f0f7;background:var(--text-1)}.nav-mobile{display:none}@media (max-width:860px){.nav-links{display:none}.nav-hamburger{display:flex}.nav-mobile.open{animation:slideDown .2s ease;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#050d18f7;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem;left:0;padding:.75rem 2rem 1.25rem;position:fixed;right:0;top:68px;z-index:999}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.nav-mobile.open a,.nav-mobile.open button{background:none;border:none;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2);color:#7e9ab5;color:var(--text-2);cursor:pointer;display:block;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;padding:.7rem .5rem;text-align:left;transition:color .2s ease;width:100%}.nav-mobile.open a:last-child,.nav-mobile.open button:last-child{border-bottom:none}.nav-mobile.open a:hover,.nav-mobile.open button:hover{color:#e8f0f7;color:var(--text-1)}}.container-wide{margin:0 auto;max-width:1180px;padding:0 2.5rem}.section-bg-default{background:#050d18;background:var(--bg)}.section-bg-alt{background:#080e1c;background:var(--bg-alt);border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2);border-top:1px solid #ffffff0d;border-top:1px solid var(--border-2)}.fade-up{opacity:0;transform:translateY(22px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1)}.fade-up.visible{opacity:1;transform:none}.fade-up.delay-1{transition-delay:.08s}.fade-up.delay-2{transition-delay:.16s}.fade-up.delay-3{transition-delay:.24s}.fade-up.delay-4{transition-delay:.32s}.fade-up.delay-5{transition-delay:.4s}.eyebrow{align-items:center;color:#12d393;color:var(--accent);display:inline-flex;font-size:.72rem;font-weight:700;gap:.5rem;letter-spacing:.15em;margin-bottom:.9rem;text-transform:uppercase}.eyebrow-dot{background:#12d393;background:var(--accent);border-radius:50%;flex-shrink:0;height:5px;width:5px}.section-heading{color:#e8f0f7;color:var(--text-1);font-family:Space Grotesk,sans-serif;font-size:clamp(1.9rem,4vw,2.9rem);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin:0 0 .65rem}.section-sub{color:#7e9ab5;color:var(--text-2);font-size:1rem;line-height:1.75;margin:0 0 2.5rem;max-width:52ch}.hero-section{align-items:center;background:#050d18;background:var(--bg);display:flex;min-height:100dvh;overflow:hidden;padding-top:68px;position:relative}.hero-section:before{animation:heroGlowA 8s ease-in-out infinite alternate;background:radial-gradient(circle,rgba(16,185,129,.065) 0,#0000 65%);height:700px;left:-12%;top:-8%;width:700px}.hero-section:after,.hero-section:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.hero-section:after{animation:heroGlowB 10s ease-in-out infinite alternate;background:radial-gradient(circle,#f973160d 0,#0000 65%);bottom:-8%;height:600px;right:-8%;width:600px}@keyframes heroGlowA{0%{opacity:.7;transform:scale(1)}to{opacity:1;transform:scale(1.08)}}@keyframes heroGlowB{0%{opacity:.6;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.hero-grid{grid-gap:3.5rem;align-items:center;display:grid;gap:3.5rem;grid-template-columns:1fr 400px;width:100%}.hero-left{position:relative;z-index:1}.hero-eyebrow{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#12d39324;background:var(--accent-dim);border:1px solid #12d39359;border:1px solid var(--accent-border);border-radius:999px;border-radius:var(--radius-pill);color:#12d393;color:var(--accent);display:inline-flex;font-size:.75rem;font-weight:600;gap:.6rem;letter-spacing:.1em;margin-bottom:1.5rem;padding:.3rem .85rem .3rem .6rem;text-transform:uppercase}.hero-eyebrow-indicator{animation:pulse-dot 2s ease-in-out infinite;background:#12d393;background:var(--accent);border-radius:50%;box-shadow:0 0 6px #10b981b3;height:6px;width:6px}.hero-title{color:#e8f0f7;color:var(--text-1);font-family:Space Grotesk,sans-serif;font-size:clamp(2.6rem,5vw,4.4rem);font-weight:700;letter-spacing:-.025em;line-height:1.05;margin:0 0 1.25rem;max-width:15ch}.hero-title em{color:#12d393;color:var(--accent);font-style:normal;position:relative}.hero-sub{color:#7e9ab5;color:var(--text-2);font-size:1.05rem;line-height:1.75;margin:0 0 2rem;max-width:44ch}.hero-ctas{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.btn-primary-g{align-items:center;background:#12d393;background:var(--accent);border:none;border-radius:999px;border-radius:var(--radius-pill);color:#021a0e;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;gap:.5rem;letter-spacing:.01em;padding:.7rem 1.4rem;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;white-space:nowrap}.btn-primary-g:hover{background:#34d399;box-shadow:0 8px 24px #10b9814d;transform:translateY(-2px)}.btn-primary-g:active{transform:translateY(0) scale(.98)}.btn-ghost{align-items:center;background:#0000;border:1px solid #ffffff1f;border-radius:999px;border-radius:var(--radius-pill);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;gap:.5rem;padding:.7rem 1.4rem;text-decoration:none!important;transition:border-color .2s ease,background .2s ease,transform .15s ease;white-space:nowrap}.btn-ghost,.btn-ghost:hover{color:#e8f0f7;color:var(--text-1)}.btn-ghost:hover{background:#ffffff0a;border-color:#ffffff40;transform:translateY(-2px)}.btn-ghost:active{transform:translateY(0) scale(.98)}.hero-right{display:flex;flex-direction:column;gap:1rem;position:relative;z-index:1}.hero-metric-card{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 24px #00000047;box-shadow:var(--shadow-sm);padding:1.2rem 1.4rem;transition:border-color .3s ease,transform .3s ease,box-shadow .3s ease}.hero-metric-card:hover{box-shadow:0 16px 40px #00000059,0 0 0 1px #12d39359;box-shadow:0 16px 40px #00000059,0 0 0 1px var(--accent-border);transform:translateY(-4px)}.hero-metric-card.accent-border,.hero-metric-card:hover{border-color:#12d39359;border-color:var(--accent-border)}.hero-metric-card.accent-border{background:linear-gradient(135deg,#10b98117,#0a1628d9)}.hero-metric-value{color:#12d393;color:var(--accent);font-family:Space Grotesk,sans-serif;font-size:1.6rem;font-weight:700;line-height:1;margin-bottom:.35rem}.hero-metric-label{color:#7e9ab5;color:var(--text-2);font-size:.86rem;line-height:1.55}.hero-metric-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media (max-width:1000px){.hero-grid{gap:2.5rem;grid-template-columns:1fr}.hero-right{display:grid;grid-template-columns:1fr 1fr}.hero-metric-row{display:contents}.hero-title{font-size:clamp(2.2rem,7vw,3.6rem)}}@media (max-width:600px){.hero-section{padding-top:80px}.hero-right{grid-template-columns:1fr}.container-wide,.portfolio-nav{padding:0 1.25rem}}.projects-section{background:#080e1c;background:var(--bg-alt);border-top:1px solid #ffffff0d;border-top:1px solid var(--border-2);padding:90px 0 80px}.projects-bento{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;margin-top:2.5rem}.project-card-featured{background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 24px #00000047;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;grid-row:1/3;overflow:hidden;transition:border-color .3s ease,transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease}.project-card-featured:hover{border-color:#12d39359;border-color:var(--accent-border);box-shadow:0 24px 60px #00000080,0 0 0 1px #12d39359;box-shadow:0 24px 60px #00000080,0 0 0 1px var(--accent-border);transform:translateY(-5px)}.project-card-small{background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 24px #00000047;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;transition:border-color .3s ease,transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease}.project-card-small:hover{border-color:#12d39359;border-color:var(--accent-border);box-shadow:0 16px 40px #0006,0 0 0 1px #12d39359;box-shadow:0 16px 40px #0006,0 0 0 1px var(--accent-border);transform:translateY(-4px)}@media (min-width:841px){.projects-bento>.project-card-small:nth-child(4){grid-column:1/-1}.projects-bento>.project-card-small:nth-child(4) .project-img-wrap{height:220px}}.project-img-wrap{flex-shrink:0;overflow:hidden;position:relative}.project-img-wrap img{display:block;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,1,.36,1);width:100%}.project-card-featured:hover .project-img-wrap img,.project-card-small:hover .project-img-wrap img{transform:scale(1.05)}.project-card-featured .project-img-wrap{height:240px}.project-card-small .project-img-wrap{height:150px}.project-img-placeholder{align-items:flex-end;background:linear-gradient(135deg,#10b9811a,#f9731612,#ffffff05);display:flex;height:100%;min-height:150px;padding:1.2rem}.project-body{display:flex;flex:1 1;flex-direction:column;gap:.65rem;padding:1.35rem}.project-role-tag{align-items:center;color:#12d393;color:var(--accent);display:inline-flex;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.project-title{color:#e8f0f7;color:var(--text-1);font-family:Space Grotesk,sans-serif;font-size:1.25rem;font-weight:700;line-height:1.25;margin:0}.project-card-featured .project-title{font-size:1.5rem}.project-summary{color:#7e9ab5;color:var(--text-2);font-size:.92rem;line-height:1.65;margin:0}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto;padding-top:.4rem}.project-tag{background:#ffffff0d;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:999px;border-radius:var(--radius-pill);color:#7e9ab5;color:var(--text-2);display:inline-flex;font-size:.74rem;font-weight:500;padding:.26rem .6rem}.project-links{display:flex;flex-wrap:wrap;gap:.55rem;padding-top:.4rem}.project-link-btn{align-items:center;background:#0000;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);color:#7e9ab5;color:var(--text-2);display:inline-flex;font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;gap:.4rem;padding:.36rem .8rem;text-decoration:none!important;transition:color .2s ease,border-color .2s ease,transform .15s ease,background .2s ease;white-space:nowrap}.project-link-btn:hover{transform:translateY(-1px)}.project-link-btn.primary,.project-link-btn:hover{background:#12d39324;background:var(--accent-dim);border-color:#12d39359;border-color:var(--accent-border);color:#12d393;color:var(--accent)}.project-link-btn.primary:hover{background:#10b98138}@media (max-width:840px){.projects-bento{grid-template-columns:1fr;grid-template-rows:auto}.project-card-featured{grid-row:auto}.project-card-featured .project-img-wrap{height:220px}}.experience-section{background:#050d18;background:var(--bg);padding:90px 0 80px}.experience-list{margin-top:2.5rem}.experience-item{grid-gap:2.5rem;border-radius:7.92px;border-radius:var(--radius-sm);border-top:1px solid #ffffff0d;border-top:1px solid var(--border-2);cursor:default;display:grid;gap:2.5rem;grid-template-columns:200px 1fr;padding:1.8rem 1rem;transition:background .25s ease}.experience-item:last-child{border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2)}.experience-item:hover{background:hsla(0,0%,100%,.018)}.exp-meta{padding-top:.15rem}.exp-company{color:#e8f0f7;color:var(--text-1);font-size:1rem;font-weight:700;margin:0 0 .35rem}.exp-company,.exp-period{font-family:Space Grotesk,sans-serif}.exp-period{color:#4e6a82;color:var(--text-3);font-size:.8rem;font-weight:500;letter-spacing:.03em}.exp-role{color:#12d393;color:var(--accent);font-size:.7rem;font-weight:700;letter-spacing:.12em;margin:0 0 .55rem;text-transform:uppercase}.exp-summary{color:#7e9ab5;color:var(--text-2);font-size:.95rem;line-height:1.7;margin:0 0 1rem}.exp-points{display:flex;flex-wrap:wrap;gap:.45rem}.exp-point-tag{align-items:center;background:#ffffff0a;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);color:#7e9ab5;color:var(--text-2);display:inline-flex;font-size:.76rem;font-weight:500;padding:.26rem .65rem;transition:border-color .2s ease,color .2s ease}.experience-item:hover .exp-point-tag{border-color:#10b98133;color:#e8f0f7;color:var(--text-1)}@media (max-width:640px){.experience-item{gap:.6rem;grid-template-columns:1fr;padding:1.4rem .5rem}}.about-section{background:#080e1c;background:var(--bg-alt);border-top:1px solid #ffffff0d;border-top:1px solid var(--border-2);padding:90px 0 80px}.about-grid{grid-gap:3.5rem;align-items:start;display:grid;gap:3.5rem;grid-template-columns:1fr 1fr;margin-top:2.5rem}.about-bio{color:#7e9ab5;color:var(--text-2);font-size:1rem;line-height:1.82;margin:0 0 2rem}.about-bio strong{color:#e8f0f7;color:var(--text-1);font-weight:600}.about-strengths{display:flex;flex-direction:column;gap:.8rem}.strength-card{background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-left:3px solid #0000;border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 24px #00000047;box-shadow:var(--shadow-sm);padding:1.1rem 1.25rem;transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease}.strength-card:hover{border-color:#12d39359;border-color:var(--accent-border);border-left-color:#12d393;border-left-color:var(--accent);box-shadow:0 12px 32px #0000004d;transform:translateX(5px)}.strength-card h3{color:#e8f0f7;color:var(--text-1);font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:700;margin:0 0 .35rem}.strength-card p{color:#7e9ab5;color:var(--text-2);font-size:.88rem;line-height:1.65;margin:0}.quickfacts-card{background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 24px #00000047;box-shadow:var(--shadow-sm);margin-bottom:1.1rem;padding:1.3rem}.quickfacts-card h3{color:#12d393;color:var(--accent);font-family:Space Grotesk,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.14em;margin:0 0 .9rem;text-transform:uppercase}.quickfacts-list{display:flex;flex-direction:column;gap:.6rem;list-style:none;margin:0;padding:0}.quickfacts-list li{align-items:flex-start;color:#7e9ab5;color:var(--text-2);display:flex;font-size:.88rem;gap:.65rem;line-height:1.6}.quickfacts-list li:before{background:#12d393;background:var(--accent);border-radius:50%;content:"";display:block;flex-shrink:0;height:5px;margin-top:.55rem;width:5px}.github-card{background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 8px 24px #00000047;box-shadow:var(--shadow-sm);overflow:hidden;padding:1.3rem}.github-card h3{color:#4e6a82;color:var(--text-3);font-family:Space Grotesk,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.14em;margin:0 0 .9rem;text-transform:uppercase}.github-calendar-wrap{overflow-x:auto}@media (max-width:840px){.about-grid{gap:2rem;grid-template-columns:1fr}}.contact-section{background:#050d18;background:var(--bg);padding:90px 0 80px}.contact-grid{grid-gap:3.5rem;align-items:start;display:grid;gap:3.5rem;grid-template-columns:1fr 1fr;margin-top:2.5rem}.contact-form{gap:1rem}.contact-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.4rem}.form-label{color:#4e6a82;color:var(--text-3);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.form-input,.form-textarea{background:#0e1c32eb;background:var(--surface-2);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:7.92px;border-radius:var(--radius-sm);color:#e8f0f7;color:var(--text-1);font-family:Inter,sans-serif;font-size:.93rem;outline:none;padding:.68rem 1rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:#4e6a82;color:var(--text-3)}.form-input:focus,.form-textarea:focus{border-color:#12d39359;border-color:var(--accent-border);box-shadow:0 0 0 3px #10b9811a}.form-textarea{min-height:130px;resize:vertical}.form-submit{align-items:center;align-self:flex-start;background:#12d393;background:var(--accent);border:none;border-radius:999px;border-radius:var(--radius-pill);color:#021a0e;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;gap:.5rem;justify-content:center;margin-top:.25rem;padding:.72rem 1.6rem;transition:background .2s ease,transform .15s ease,box-shadow .2s ease;white-space:nowrap}.form-submit:hover:not(:disabled){background:#34d399;box-shadow:0 8px 24px #10b9814d;transform:translateY(-2px)}.form-submit:active:not(:disabled){transform:translateY(0) scale(.98)}.form-submit:disabled{cursor:not-allowed;opacity:.4}.contact-cta-text{color:#7e9ab5;color:var(--text-2);font-size:1rem;line-height:1.75;margin:0 0 1.75rem}.contact-cta-text strong{color:#e8f0f7;color:var(--text-1);font-weight:600}.social-grid{display:flex;flex-direction:column;gap:.65rem}.social-item{align-items:center;background:#0a1628e0;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);display:flex;gap:1rem;padding:.85rem 1rem;text-decoration:none!important;transition:border-color .25s ease,transform .25s ease,background .25s ease}.social-item:hover{background:#10b9810a;border-color:#12d39359;border-color:var(--accent-border);transform:translateX(4px)}.social-icon-wrap{align-items:center;background:#ffffff0d;border-radius:7.92px;border-radius:var(--radius-sm);color:#7e9ab5;color:var(--text-2);display:flex;flex-shrink:0;font-size:1.1rem;height:38px;justify-content:center;transition:color .2s ease,background .2s ease;width:38px}.social-item:hover .social-icon-wrap{background:#12d39324;background:var(--accent-dim);color:#12d393;color:var(--accent)}.social-platform{color:#e8f0f7;color:var(--text-1);display:block;font-size:.88rem;font-weight:600;line-height:1.25;margin-bottom:.1rem}.social-handle{color:#4e6a82;color:var(--text-3);font-size:.78rem}.social-label{color:#12d393;color:var(--accent);font-size:.72rem;font-weight:600;margin-left:auto;opacity:0;transition:opacity .2s ease}.social-item:hover .social-label{opacity:1}.resume-download{align-items:center;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);color:#7e9ab5;color:var(--text-2);display:inline-flex;font-family:Inter,sans-serif;font-size:.86rem;font-weight:600;gap:.5rem;margin-top:1.1rem;padding:.65rem 1.25rem;text-decoration:none!important;transition:color .2s,border-color .2s,transform .15s,background .2s}.resume-download:hover{background:#12d39324;background:var(--accent-dim);border-color:#12d39359;border-color:var(--accent-border);color:#12d393;color:var(--accent);transform:translateY(-2px)}@media (max-width:760px){.contact-grid{gap:2.5rem;grid-template-columns:1fr}}.portfolio-footer{align-items:center;background:#080e1c;background:var(--bg-alt);border-top:1px solid #ffffff0d;border-top:1px solid var(--border-2);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2.5rem}.footer-copy{color:#4e6a82;color:var(--text-3);font-family:Inter,sans-serif;font-size:.82rem}.footer-copy span{color:#12d393;color:var(--accent);font-weight:600}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:#4e6a82;color:var(--text-3);font-family:Inter,sans-serif;font-size:.82rem;text-decoration:none!important;transition:color .2s ease}.footer-links a:hover{color:#7e9ab5;color:var(--text-2)}@media (max-width:560px){.portfolio-footer{flex-direction:column;text-align:center}.container-wide,.portfolio-nav{padding:0 1.25rem}}.text-accent{color:#12d393;color:var(--accent)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.project-card-n8n{display:grid;grid-column:1/-1;grid-template-rows:auto auto}@media (min-width:841px){.project-card-n8n{grid-template-columns:1.5fr 1fr;grid-template-rows:1fr}.project-card-n8n .n8n-simulator-wrapper{border-right:1px solid #ffffff0d;border-right:1px solid var(--border-2)}}.n8n-simulator-wrapper{background:#040914f2;display:flex;flex-direction:column;font-family:Inter,sans-serif;gap:1rem;padding:1.5rem}.n8n-header{border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2);flex-wrap:wrap;gap:.6rem;justify-content:space-between;padding-bottom:.8rem}.n8n-brand,.n8n-header{align-items:center;display:flex}.n8n-brand{gap:.5rem}.n8n-dot-glow{background-color:#12d393;background-color:var(--accent);border-radius:50%;box-shadow:0 0 10px #12d393;box-shadow:0 0 10px var(--accent);display:inline-block;height:8px;width:8px}.n8n-title{color:#e8f0f7;color:var(--text-1);font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.n8n-flow-tabs{background:#ffffff08;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:7.92px;border-radius:var(--radius-sm);display:flex;padding:.2rem}.n8n-tab-btn{background:#0000;border:none;border-radius:5.92px;border-radius:calc(var(--radius-sm) - 2px);color:#7e9ab5;color:var(--text-2);cursor:pointer;font-size:.76rem;font-weight:600;padding:.35rem .75rem;transition:all .25s ease}.n8n-tab-btn.active{background:#ffffff0a;background:var(--surface-soft);color:#12d393;color:var(--accent)}.n8n-canvas{background:#02060c99;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:7.92px;border-radius:var(--radius-sm);overflow:hidden;padding:1.25rem .5rem;position:relative}.n8n-svg-lines{height:80px;left:0;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:100%;z-index:1}.n8n-pulse-line{stroke-dasharray:10,500;stroke-dashoffset:10;animation:strokePulse 1.5s linear infinite}@keyframes strokePulse{to{stroke-dashoffset:-500}}.n8n-nodes-row{display:flex;gap:.5rem;justify-content:space-around;position:relative;z-index:2}.n8n-node-card{align-items:center;background:#0a1628e6;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:7.92px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:.4rem;padding:.5rem .25rem;text-align:center;transition:all .35s cubic-bezier(.22,1,.36,1);width:78px}.n8n-node-card.active{background:#12d39324;background:var(--accent-dim);border-color:#12d393;border-color:var(--accent);box-shadow:0 0 15px #12d39324;box-shadow:0 0 15px var(--accent-dim);transform:translateY(-2px)}.n8n-node-card.passed{border-color:#fff3;opacity:.8}.n8n-node-icon-wrap{align-items:center;background:#ffffff08;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:50%;display:flex;height:28px;justify-content:center;width:28px}.n8n-node-card.active .n8n-node-icon-wrap{background:#ffffff0f;border-color:#12d39359;border-color:var(--accent-border)}.n8n-icon{font-size:.85rem}.n8n-node-label{color:#7e9ab5;color:var(--text-2);font-size:.62rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.n8n-node-card.active .n8n-node-label{color:#e8f0f7;color:var(--text-1)}.n8n-terminal{background:#02060c;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:7.92px;border-radius:var(--radius-sm);display:flex;flex-direction:column;height:150px;overflow:hidden}.terminal-header{align-items:center;background:#ffffff05;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2);display:flex;justify-content:space-between;padding:.5rem .75rem}.terminal-dots{display:flex;gap:.3rem}.terminal-dots .dot{border-radius:50%;display:inline-block;height:6px;width:6px}.terminal-dots .dot.red{background:#ef4444}.terminal-dots .dot.yellow{background:#f59e0b}.terminal-dots .dot.green{background:#10b981}.terminal-title{color:#4e6a82;color:var(--text-3);font-size:.65rem}.terminal-body,.terminal-title{font-family:JetBrains Mono,monospace}.terminal-body{display:flex;flex:1 1;flex-direction:column;font-size:.68rem;gap:.4rem;line-height:1.5;overflow-y:auto;padding:.75rem}.terminal-idle{color:#4e6a82;color:var(--text-3)}.terminal-line{word-break:break-all}.terminal-line.info{color:#7e9ab5;color:var(--text-2)}.terminal-line.warn{color:#f97316;color:var(--warm)}.terminal-line.success{color:#12d393;color:var(--accent)}.terminal-time{color:#4e6a82;color:var(--text-3);margin-right:.35rem}.terminal-prompt{font-weight:700;margin-right:.35rem}.cursor-blink,.terminal-prompt{color:#12d393;color:var(--accent)}.cursor-blink{animation:cursorBlink .8s infinite}@keyframes cursorBlink{50%{opacity:0}}.n8n-controls{display:flex;justify-content:center}.n8n-btn{border:1px solid #ffffff14;border:1px solid var(--border);border-radius:999px;border-radius:var(--radius-pill);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:700;padding:.5rem 1.25rem;transition:all .25s ease}.n8n-btn.run{background:#12d39324;background:var(--accent-dim);border-color:#12d39359;border-color:var(--accent-border);color:#12d393;color:var(--accent)}.n8n-btn.run:hover{background:#12d393;background:var(--accent);box-shadow:0 0 15px #12d39324;box-shadow:0 0 15px var(--accent-dim);color:#050d18;color:var(--bg)}.n8n-btn.stop{background:#ef44441f;border-color:#ef44444d;color:#f87171}.n8n-btn.stop:hover{background:#ef4444;color:#fff}.devtools-badge{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#0a1628d9;border:1px solid #12d39359;border:1px solid var(--accent-border);border-radius:999px;border-radius:var(--radius-pill);bottom:24px;box-shadow:0 10px 30px #00000080,0 0 1px 1px #12d39359;box-shadow:0 10px 30px #00000080,0 0 1px 1px var(--accent-border);color:#e8f0f7;color:var(--text-1);cursor:pointer;display:flex;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:700;gap:.5rem;padding:.6rem 1.1rem;position:fixed;right:24px;transition:all .3s cubic-bezier(.22,1,.36,1);z-index:99999}.devtools-badge:hover{box-shadow:0 15px 40px #0009,0 0 8px #12d39324;box-shadow:0 15px 40px #0009,0 0 8px var(--accent-dim);transform:translateY(-2px)}.devtools-badge.active,.devtools-badge:hover{border-color:#12d393;border-color:var(--accent)}.devtools-badge.active{color:#050d18;color:var(--bg)}.badge-pulse,.devtools-badge.active{background:#12d393;background:var(--accent)}.badge-pulse{border-radius:50%;height:8px;position:absolute;right:-2px;top:-2px;width:8px}.devtools-badge.active .badge-pulse{background:#e8f0f7;background:var(--text-1)}.devtools-badge.active .badge-pulse:after{display:none}.badge-pulse:after{animation:radarPulse 1.8s infinite;border:1px solid #12d393;border:1px solid var(--accent);border-radius:50%;content:"";inset:0;position:absolute}@keyframes radarPulse{to{opacity:0;transform:scale(3.5)}}.devtools-drawer{background:#060e1afa;border-left:1px solid #ffffff14;border-left:1px solid var(--border);box-shadow:-20px 0 60px #000000b3;display:flex;flex-direction:column;height:100dvh;position:fixed;right:-420px;top:0;transition:transform .4s cubic-bezier(.22,1,.36,1);width:380px;z-index:99998}.devtools-drawer.open{transform:translateX(-420px)}.drawer-header{align-items:center;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2);display:flex;justify-content:space-between;padding:1.25rem}.drawer-title{color:#e8f0f7;color:var(--text-1);font-family:JetBrains Mono,monospace;font-size:.95rem;font-weight:700}.drawer-close{background:#0000;border:none;color:#4e6a82;color:var(--text-3);cursor:pointer;font-size:1.5rem;transition:color .2s ease}.drawer-close:hover{color:#12d393;color:var(--accent)}.drawer-tabs{background:#ffffff03;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-2);display:flex}.drawer-tab-btn{background:#0000;border:none;border-bottom:2px solid #0000;color:#4e6a82;color:var(--text-3);cursor:pointer;flex:1 1;font-family:Space Grotesk,sans-serif;font-size:.76rem;font-weight:600;padding:.75rem .5rem;transition:all .2s ease}.drawer-tab-btn:hover{color:#7e9ab5;color:var(--text-2)}.drawer-tab-btn.active{background:hsla(0,0%,100%,.015);border-bottom-color:#12d393;border-bottom-color:var(--accent);color:#12d393;color:var(--accent)}.drawer-body{flex:1 1;overflow-y:auto;padding:1.5rem}.tab-pane{display:flex;flex-direction:column;gap:1.5rem}.metric-row{display:flex;gap:1rem}.metric-card{background:#ffffff05;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:7.92px;border-radius:var(--radius-sm);display:flex;flex:1 1;flex-direction:column;gap:.3rem;padding:.8rem}.metric-title{color:#4e6a82;color:var(--text-3);font-size:.65rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.metric-value{font-family:JetBrains Mono,monospace;font-size:1.15rem;font-weight:700}.metric-value.green{color:#12d393;color:var(--accent)}.metric-value.blue{color:#3b82f6}.perf-graph-title{color:#7e9ab5;color:var(--text-2);font-family:Space Grotesk,sans-serif;font-size:.76rem;font-weight:700}.graph-sub{color:#4e6a82;color:var(--text-3);font-size:.65rem;font-weight:400}.canvas-wrapper{background:#02060c80;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:7.92px;border-radius:var(--radius-sm);display:flex;justify-content:center;padding:.5rem}.perf-checklist{display:flex;flex-direction:column;gap:.6rem;margin-top:.5rem}.check-item{font-size:.78rem;gap:.6rem}.check-icon,.check-item{align-items:center;display:flex}.check-icon{background:#10b9811a;border:1px solid #12d393;border:1px solid var(--accent);border-radius:50%;color:#12d393;color:var(--accent);font-size:.6rem;font-weight:700;height:14px;justify-content:center;width:14px}.check-label{color:#7e9ab5;color:var(--text-2)}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-label{color:#7e9ab5;color:var(--text-2);display:flex;font-size:.78rem;font-weight:600;justify-content:space-between}.control-val{color:#12d393;color:var(--accent);font-family:JetBrains Mono,monospace}.theme-slider{-webkit-appearance:none;appearance:none;background:#ffffff14;border-radius:999px;border-radius:var(--radius-pill);height:5px;outline:none;width:100%}.theme-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#12d393;background:var(--accent);border:2px solid #050d18;border:2px solid var(--bg);border-radius:50%;box-shadow:0 0 10px #12d39324;box-shadow:0 0 10px var(--accent-dim);cursor:pointer;height:15px;width:15px}.hue-preview-bar{background:linear-gradient(90deg,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red);border-radius:999px;border-radius:var(--radius-pill);height:6px;opacity:.7}.font-selectors{display:flex;flex-direction:column;gap:.5rem}.font-btn{background:hsla(0,0%,100%,.015);border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:7.92px;border-radius:var(--radius-sm);color:#7e9ab5;color:var(--text-2);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:600;padding:.6rem .8rem;text-align:left;transition:all .2s ease}.font-btn:hover{background:#ffffff08}.font-btn.active,.font-btn:hover{color:#e8f0f7;color:var(--text-1)}.font-btn.active{background:#12d39324;background:var(--accent-dim);border-color:#12d393;border-color:var(--accent)}.reset-theme-btn{background:#0000;border:1px dashed #12d39359;border:1px dashed var(--accent-border);border-radius:7.92px;border-radius:var(--radius-sm);color:#12d393;color:var(--accent);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:700;margin-top:1rem;padding:.7rem;transition:all .25s ease}.reset-theme-btn:hover{background:#12d39324;background:var(--accent-dim);border-color:#12d393;border-color:var(--accent);border-style:solid}.code-header{background:#ffffff05;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-bottom:none;border-radius:7.92px 7.92px 0 0;border-radius:var(--radius-sm) var(--radius-sm) 0 0;color:#4e6a82;color:var(--text-3);display:flex;font-size:.65rem;justify-content:space-between;padding:.4rem .6rem}.code-viewer{background:#02060c;border:1px solid #ffffff0d;border:1px solid var(--border-2);border-radius:0 0 7.92px 7.92px;border-radius:0 0 var(--radius-sm) var(--radius-sm);color:#9cb3c9;font-family:JetBrains Mono,monospace;font-size:.62rem;line-height:1.5;margin:0;max-height:280px;overflow-y:auto;padding:.8rem}.drawer-footer{background:hsla(0,0%,100%,.015);border-top:1px solid #ffffff0d;border-top:1px solid var(--border-2);color:#4e6a82;color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.6rem;justify-content:space-between;padding:.75rem 1.25rem}.active-badge,.drawer-footer{align-items:center;display:flex}.active-badge{color:#12d393;color:var(--accent);gap:.25rem}.active-badge:before{background:#12d393;background:var(--accent);border-radius:50%;box-shadow:0 0 5px #12d393;box-shadow:0 0 5px var(--accent);content:"";display:inline-block;height:5px;width:5px}@media (max-width:420px){.devtools-drawer{right:-105vw;width:100vw}.devtools-drawer.open{transform:translateX(-105vw)}}:root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;background-color:#050d18;color:#e8f0f7;color-scheme:dark;font-family:Inter,sans-serif;font-size:16px;font-synthesis:none;font-weight:400;line-height:24px;text-rendering:optimizeLegibility}*,:after,:before{box-sizing:border-box;margin:0;padding:0;text-decoration:none}body{background:#050d18;color:#e8f0f7;margin:0;min-height:100vh}img{height:auto;max-width:100%}
/*# sourceMappingURL=main.abbdcb90.css.map*/