@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_f15bd114-module__7725RG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_f15bd114-module__7725RG__variable{--font-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_6ed36146-module__KdPPOG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_6ed36146-module__KdPPOG__variable{--font-mono:"Geist Mono","Geist Mono Fallback"}
:root{--bg:#0b0d12;--bg-alt:#111827;--surface:#141a24;--surface-light:#1b2230;--text:#f3f4f6;--muted:#9ca3af;--accent:#7dd3fc;--accent-strong:#38bdf8;--accent-glow:#38bdf880;--line:#94a3b833;--line-glow:#7dd3fc66;--gradient-primary:linear-gradient(120deg,var(--accent),var(--accent-strong));--gradient-glass:linear-gradient(140deg,#7dd3fc1a,#0f172acc);--gradient-orb-1:radial-gradient(circle,#38bdf866,transparent 70%);--gradient-orb-2:radial-gradient(circle,#7dd3fc4d,transparent 60%);--gradient-orb-3:radial-gradient(circle,#60a5fa40,transparent 65%);--shadow-sm:0 4px 12px #0f172a33;--shadow-md:0 16px 40px #0f172a59;--shadow-lg:0 24px 60px #0f172a80;--shadow-glow:0 0 30px #38bdf84d;--shadow-glow-strong:0 0 50px #38bdf880;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:60px;--space-3xl:80px;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--radius-full:999px;--duration-instant:.1s;--duration-fast:.15s;--duration-normal:.3s;--duration-slow:.5s;--duration-slower:.7s;--ease-default:cubic-bezier(.4,0,.2,1);--ease-bounce:cubic-bezier(.34,1.56,.64,1);--ease-smooth:cubic-bezier(.25,.1,.25,1);--ease-out:cubic-bezier(0,0,.2,1);--ease-in-out:cubic-bezier(.4,0,.2,1);--stagger-delay:50ms;--reveal-distance:30px;--z-base:0;--z-elevated:10;--z-header:20;--z-modal:30;--z-tooltip:40;--z-max:50;--blur-sm:4px;--blur-md:12px;--blur-lg:24px;--blur-xl:40px}@media (prefers-reduced-motion:reduce){:root{--duration-instant:0s;--duration-fast:0s;--duration-normal:0s;--duration-slow:0s;--duration-slower:0s;--reveal-distance:0px;--stagger-delay:0s}}
@keyframes float-orb-1{0%,to{opacity:.6;transform:translate(0)scale(1)}25%{opacity:.8;transform:translate(30px,-20px)scale(1.1)}50%{opacity:.5;transform:translate(-20px,30px)scale(.95)}75%{opacity:.7;transform:translate(15px,15px)scale(1.05)}}@keyframes float-orb-2{0%,to{opacity:.5;transform:translate(0)scale(1)}33%{opacity:.7;transform:translate(-40px,20px)scale(1.15)}66%{opacity:.4;transform:translate(25px,-30px)scale(.9)}}@keyframes float-orb-3{0%,to{opacity:.4;transform:translate(0)scale(1)}50%{opacity:.6;transform:translate(20px,40px)scale(1.1)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #38bdf833}50%{box-shadow:0 0 40px #38bdf866}}@keyframes border-glow{0%,to{border-color:var(--line)}50%{border-color:var(--line-glow)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes underline-sweep{0%{transform-origin:0;transform:scaleX(0)}to{transform-origin:0;transform:scaleX(1)}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(var(--reveal-distance))}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-float-1{animation:20s ease-in-out infinite float-orb-1}.animate-float-2{animation:25s ease-in-out infinite float-orb-2}.animate-float-3{animation:18s ease-in-out infinite float-orb-3}.animate-glow-pulse{animation:3s ease-in-out infinite glow-pulse}.animate-shimmer{background:linear-gradient(90deg,#0000 0%,#7dd3fc1a 50%,#0000 100%) 0 0/200% 100%;animation:3s ease-in-out infinite shimmer}.animate-fade-in-up{animation:fade-in-up var(--duration-normal)var(--ease-out)forwards}.animate-fade-in{animation:fade-in var(--duration-normal)var(--ease-out)forwards}.animate-scale-in{animation:scale-in var(--duration-normal)var(--ease-bounce)forwards}.animate-spin{animation:1s linear infinite spin}.transition-all{transition:all var(--duration-normal)var(--ease-default)}.transition-transform{transition:transform var(--duration-fast)var(--ease-default)}.transition-colors{transition:color var(--duration-fast)var(--ease-default),background-color var(--duration-fast)var(--ease-default),border-color var(--duration-fast)var(--ease-default)}.transition-opacity{transition:opacity var(--duration-fast)var(--ease-default)}.transition-shadow{transition:box-shadow var(--duration-normal)var(--ease-default)}.perspective-container{perspective:1000px}.preserve-3d{transform-style:preserve-3d}@media (prefers-reduced-motion:reduce){.animate-float-1,.animate-float-2,.animate-float-3,.animate-glow-pulse,.animate-shimmer{animation:none}.animate-fade-in-up,.animate-fade-in,.animate-scale-in{opacity:1;animation:none;transform:none}.transition-all,.transition-transform,.transition-colors,.transition-opacity,.transition-shadow{transition:none}}
*{box-sizing:border-box;margin:0;padding:0}html{overscroll-behavior:none;scroll-behavior:smooth;background-color:#050709}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{min-height:100vh;color:var(--text);line-height:1.7;font-family:var(--font-sans),system-ui,-apple-system,BlinkMacSystemFont,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;background-color:#050709;background-image:radial-gradient(80% 50% at 50% -20%,#38bdf826,#0000),radial-gradient(60% 40% at 10% 20%,#7dd3fc1a,#0000),radial-gradient(50% 30% at 90% 80%,#60a5fa14,#0000),linear-gradient(#0b0d12 0%,#0a0e15 50%,#080a0f 100%);background-attachment:fixed;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:9999;opacity:.015;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)'/%3E%3C/svg%3E");width:100%;height:100%;position:fixed;top:0;left:0}main,.hero,.section,.container,.cards,.card,.glass-card,.panel,.split,.skills-grid,.feature-list,.nav-cta,h1,h2,h3,h4,p,.badge,.btn{opacity:1;visibility:visible;transform:none}@media (prefers-reduced-motion:no-preference){.hero>*,.section>*,.container>*{opacity:1}}h1,h2,h3,h4{font-family:var(--font-serif),Georgia,serif;letter-spacing:-.02em;text-wrap:balance;font-weight:600}h1{background:linear-gradient(135deg,var(--text)0%,var(--accent)100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}h2,h3{color:var(--text)}p{text-wrap:pretty}a{color:inherit;transition:color var(--duration-fast)var(--ease-default);text-decoration:none}::selection{color:var(--text);background:#38bdf84d}img{max-width:100%;height:auto;display:block}img,video{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}.container{width:min(1100px,92vw);margin:0 auto}.site-header{z-index:var(--z-header);-webkit-backdrop-filter:blur(16px)saturate(180%);background:linear-gradient(#0b0d12d9 0%,#0b0d12bf 100%);border-bottom:1px solid #94a3b814;position:sticky;top:0;box-shadow:0 1px #ffffff05}.header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px;padding:18px 0;display:flex}.logo{letter-spacing:.2px;align-items:center;gap:10px;font-weight:600;display:inline-flex}.logo-mark{border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.logo-text{font-size:1.05rem}.nav-links{color:var(--muted);flex-wrap:wrap;gap:18px;display:flex}.nav-links a:hover{color:var(--text)}.nav-cta{flex-wrap:wrap;gap:12px;display:flex}.btn{letter-spacing:.01em;transition:transform var(--duration-fast)var(--ease-default),box-shadow var(--duration-normal)var(--ease-default),background var(--duration-fast)var(--ease-default),border-color var(--duration-fast)var(--ease-default);cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:11px 20px;font-size:.95rem;font-weight:600;display:inline-flex;position:relative}.btn-primary{background:linear-gradient(135deg,var(--accent)0%,var(--accent-strong)100%);color:#0b0d12;text-shadow:0 1px #ffffff1a;box-shadow:0 4px 12px #38bdf840,0 8px 24px #38bdf826,inset 0 1px #fff3}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #38bdf859,0 12px 32px #38bdf833,inset 0 1px #ffffff40}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px #38bdf84d,inset 0 1px #ffffff26}.btn-outline{color:var(--text);background:#7dd3fc08;border-color:#7dd3fc66}.btn-outline:hover{background:#7dd3fc1a;border-color:#7dd3fc99;box-shadow:0 0 20px #38bdf81a}.btn-outline:active{background:#7dd3fc26}.btn-ghost{color:var(--text);border-color:#94a3b840}.btn-ghost:hover{background:#94a3b81a;border-color:#94a3b866}.btn-ghost:active{background:#94a3b826}.hero{padding:100px 0 60px;position:relative}.hero-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:center;gap:36px;display:grid}.hero h1{letter-spacing:-.03em;margin-bottom:20px;font-size:clamp(2.6rem,4vw,3.8rem);line-height:1.08}.hero p{color:var(--muted);margin-bottom:24px;font-size:1.1rem;line-height:1.8}.hero-card{border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),inset 0 1px 0 #ffffff0a;-webkit-backdrop-filter:blur(8px);background:linear-gradient(145deg,#7dd3fc14 0%,#0f172ad9 100%);padding:28px}.section{padding:40px 0}.section h2{margin-bottom:14px;font-size:clamp(1.6rem,2vw,2.2rem)}.muted{color:var(--muted)}.cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:18px;display:grid}.card{background:linear-gradient(145deg,var(--surface)0%,#141a24cc 100%);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md),inset 0 1px 0 #ffffff08;transition:transform var(--duration-fast)var(--ease-default),box-shadow var(--duration-normal)var(--ease-default),border-color var(--duration-normal)var(--ease-default);padding:22px;position:relative}.card:hover{box-shadow:var(--shadow-lg),0 0 40px #38bdf80d,inset 0 1px 0 #ffffff0d;border-color:#7dd3fc40;transform:translateY(-3px)}.glass-card{-webkit-backdrop-filter:blur(var(--blur-md));border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md),inset 0 1px 0 #ffffff0a,inset 0 0 0 1px #ffffff05;transition:border-color var(--duration-normal)var(--ease-default),box-shadow var(--duration-normal)var(--ease-default);cursor:pointer;background:linear-gradient(145deg,#7dd3fc0f 0%,#0f172ad9 50%,#0a0f19e6 100%);padding:22px;position:relative;overflow:hidden}.glass-card:before{content:"";opacity:0;height:1px;transition:opacity var(--duration-normal)var(--ease-default);background:linear-gradient(90deg,#0000 0%,#7dd3fc33 50%,#0000 100%);position:absolute;top:0;left:0;right:0}.glass-card:hover{border-color:var(--line-glow);box-shadow:var(--shadow-lg),0 0 50px #38bdf814,inset 0 1px 0 #ffffff0f}.glass-card:hover:before{opacity:1}.card h3{margin-bottom:8px;font-size:1.1rem}.card-link{display:block}.badge{color:var(--accent);letter-spacing:.02em;text-transform:uppercase;-webkit-backdrop-filter:blur(4px);background:linear-gradient(135deg,#7dd3fc26,#38bdf814);border:1px solid #7dd3fc33;border-radius:999px;align-items:center;gap:8px;padding:6px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.split{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:26px;display:grid}.panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(160deg,#1b2230e6 0%,#141a24f2 100%);padding:26px;position:relative;box-shadow:0 8px 32px #0003,inset 0 1px #ffffff08}.form-grid{gap:14px;display:grid}.field{gap:6px;display:grid}.input,.select,.textarea{border-radius:var(--radius-md);color:var(--text);background:linear-gradient(#0f172acc 0%,#0a0f19e6 100%);border:1px solid #94a3b833;padding:12px 16px;box-shadow:inset 0 2px 4px #0003,0 1px #ffffff05}.input::placeholder,.textarea::placeholder{color:#94a3b880}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);outline:none;box-shadow:inset 0 2px 4px #0003,0 0 0 3px #38bdf826,0 0 20px #38bdf81a}.textarea{resize:vertical;min-height:140px;line-height:1.6}.error{color:#fca5a5;font-size:.85rem}.notice{color:var(--accent);background:#38bdf814;border:1px solid #38bdf866;border-radius:12px;padding:12px 14px;font-size:.9rem}.success{color:#bbf7d0;background:#22c55e1a;border:1px solid #22c55e66;border-radius:12px;padding:12px 14px;font-size:.9rem}.site-footer{background:linear-gradient(#0000 0%,#05070980 100%);border-top:1px solid #94a3b81a;margin-top:80px;padding:50px 0 28px;position:relative}.site-footer:before{content:"";background:linear-gradient(90deg,#0000 0%,#38bdf84d 50%,#0000 100%);width:60%;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%)}.footer-inner{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:start;gap:20px;display:grid}.footer-logo{align-items:center;gap:10px;margin-bottom:8px;font-weight:600;display:flex}.footer-links{color:var(--muted);gap:8px;display:grid}.footer-links a:hover{color:var(--text)}.footer-bottom{text-align:center;color:var(--muted);margin-top:24px;font-size:.85rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:18px;display:grid}.skill-item{border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(135deg,#141a24e6 0%,#0f141ef2 100%);padding:14px 18px;font-size:.92rem;font-weight:500;box-shadow:0 2px 8px #00000026,inset 0 1px #ffffff08}.social-links{gap:12px;margin-top:16px;display:flex}.social-links a{color:var(--muted);transition:color .2s}.social-links a:hover{color:var(--accent)}.project-header{margin-bottom:30px}.project-header h1{margin-bottom:12px;font-size:clamp(2rem,2.5vw,2.8rem)}.back-link{color:var(--muted);align-items:center;gap:6px;margin-bottom:20px;font-size:.9rem;display:inline-flex}.back-link:hover{color:var(--accent)}.feature-list{gap:12px;margin-top:16px;list-style:none;display:grid}.feature-list li{padding-left:24px;position:relative}.feature-list li:before{content:"→";color:var(--accent);position:absolute;left:0}.btn:focus-visible,.glass-card:focus-visible,.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.input:focus-visible,.textarea:focus-visible,.select:focus-visible{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #38bdf833}.input,.textarea,.select{transition:border-color var(--duration-fast)var(--ease-default),box-shadow var(--duration-fast)var(--ease-default)}.badge{transition:transform var(--duration-fast)var(--ease-default),background var(--duration-fast)var(--ease-default)}.skill-item{transition:transform var(--duration-fast)var(--ease-default),border-color var(--duration-fast)var(--ease-default),background var(--duration-fast)var(--ease-default)}.panel{transition:box-shadow var(--duration-normal)var(--ease-default),border-color var(--duration-normal)var(--ease-default)}.panel:hover{border-color:#7dd3fc33}@media (max-width:1024px){.container{width:min(1100px,94vw)}.hero-grid{gap:24px}.cards{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.split{gap:22px}}@media (max-width:768px){.container{width:min(1100px,90vw)}.header-inner{gap:12px;padding:14px 0}.logo-text{font-size:.95rem}.nav-links{display:none}.nav-cta{width:100%}.nav-cta .btn{flex:1;padding:10px 14px;font-size:.9rem}.hero{padding:40px 0 28px}.hero h1{margin-bottom:14px;font-size:clamp(1.8rem,6vw,2.4rem)}.hero p{font-size:.95rem}.hero-grid{grid-template-columns:1fr;gap:20px}.section{padding:32px 0}.section h2{margin-bottom:12px;font-size:clamp(1.4rem,4vw,1.8rem)}.cards{grid-template-columns:1fr;gap:14px}.card,.glass-card{border-radius:16px;padding:18px}.card h3{font-size:1rem}.split{grid-template-columns:1fr;gap:18px}.panel{border-radius:16px;padding:18px}.skills-grid{grid-template-columns:1fr 1fr;gap:10px}.skill-item{border-radius:10px;padding:12px 14px;font-size:.85rem}.badge{padding:5px 10px;font-size:.8rem}.footer-inner{text-align:center;grid-template-columns:1fr;gap:24px}.footer-logo{justify-content:center}.footer-links{text-align:center}.site-footer{margin-top:40px;padding:32px 0 20px}.project-header h1{font-size:clamp(1.6rem,5vw,2rem)}.feature-list{gap:10px}.back-link{margin-bottom:16px;font-size:.85rem}.form-grid{gap:12px}.input,.select,.textarea{padding:12px 14px;font-size:16px}.btn{padding:12px 18px;font-size:.95rem}}@media (max-width:480px){.container{width:min(1100px,88vw)}.hero h1{font-size:1.6rem}.skills-grid{grid-template-columns:1fr}.hero-card{padding:18px}.nav-cta .btn{padding:10px 12px;font-size:.85rem}}@media (hover:none) and (pointer:coarse){.btn{min-height:44px}.nav-links a,.footer-links a{padding:8px 0}.card:hover,.glass-card:hover,.skill-item:hover{transform:none}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.glass-card,.card,.panel{border-width:.5px}}@supports (padding:max(0px)){.site-header{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}.site-footer{padding-bottom:max(20px,env(safe-area-inset-bottom))}}@media (max-height:500px) and (orientation:landscape){.hero{padding:30px 0 20px}.section{padding:24px 0}}
