@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600&family=Space+Grotesk:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #05070b;--color-bg-secondary: #0b111a;--color-surface: #0f1826;--color-text: #e8f4ff;--color-text-muted: #8aa0b8;--color-primary: #28d9ff;--color-secondary: #60f5c7;--color-accent: #8cffb2;--color-border: rgba(40, 217, 255, .2);--color-glow: rgba(40, 217, 255, .35);--scroll-offset: 0px;--font-sans: "Space Grotesk", "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}html{scroll-behavior:smooth;scroll-padding-top:var(--scroll-offset)}main section{scroll-margin-top:var(--scroll-offset)}body{font-family:var(--font-sans);background-color:var(--color-bg);background-image:radial-gradient(circle at top,rgba(40,217,255,.12),transparent 55%),radial-gradient(circle at 20% 20%,rgba(96,245,199,.1),transparent 45%),radial-gradient(circle at 80% 0%,rgba(140,255,178,.08),transparent 40%);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;position:relative;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:120px 120px;opacity:.2;pointer-events:none;z-index:0}body:after{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 50% 50%,#0000 60%,#0009),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");background-position:0 0,0 0;mix-blend-mode:screen;opacity:.25;pointer-events:none;z-index:0;animation:dust-drift 60s linear infinite}@keyframes dust-drift{0%{background-position:0 0,0 0}to{background-position:0 0,180px 240px}}.app{position:relative;z-index:1}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#05070bcc;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(40,217,255,.12);box-shadow:0 12px 30px #05070b66}.navbar-brand a{font-family:var(--font-mono)}.navbar-brand{display:flex;align-items:center}.brand-tag{display:inline-flex;align-items:center;justify-content:center;padding:.4rem .9rem;border-radius:999px;border:1px solid rgba(40,217,255,.4);color:var(--color-primary);background:#28d9ff1f;font-size:.9rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.navbar-links{display:flex;gap:2rem;list-style:none;margin-left:auto}.navbar-links a{font-size:.9rem;font-weight:500;color:var(--color-text-muted);transition:color .2s,text-shadow .2s}.navbar-links a:hover{color:var(--color-text);text-shadow:0 0 12px rgba(40,217,255,.35)}.language-selector{position:relative;margin-left:1.5rem}.language-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:#0f182699;border:1px solid rgba(40,217,255,.25);border-radius:10px;color:var(--color-text-muted);cursor:pointer;transition:all .2s;font-family:var(--font-sans);font-size:.85rem}.language-btn:hover{border-color:var(--color-primary);color:var(--color-text)}.globe-icon{width:18px;height:18px}.current-lang{font-weight:600;font-size:.75rem}.chevron-icon{width:14px;height:14px;transition:transform .2s}.chevron-icon.open{transform:rotate(180deg)}.language-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:140px;background:#0e1824f2;border:1px solid rgba(40,217,255,.25);border-radius:12px;padding:.5rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 30px #05070b99;z-index:101}.language-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .75rem;background:transparent;border:none;border-radius:8px;color:var(--color-text-muted);cursor:pointer;transition:all .15s;font-family:var(--font-sans);font-size:.85rem}.language-option:hover{background:#28d9ff1a;color:var(--color-text)}.language-option.active{background:#28d9ff26;color:var(--color-primary)}.lang-flag{font-weight:700;font-size:.75rem;padding:.15rem .4rem;background:#28d9ff26;border-radius:4px}.lang-label{font-weight:500}.btn{display:inline-block;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;border-radius:999px;transition:all .25s;cursor:pointer;border:1px solid transparent}.btn-primary{background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));color:#041017;box-shadow:0 10px 30px #28d9ff40}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 34px #28d9ff59}.btn-secondary{background:#0f1826b3;color:var(--color-text);border:1px solid rgba(40,217,255,.3)}.btn-secondary:hover{border-color:var(--color-primary);transform:translateY(-3px)}.btn-small{padding:.5rem 1rem;font-size:.8rem;background:#0f1826d9;border:1px solid rgba(40,217,255,.2);color:var(--color-text);border-radius:10px}.btn-small:hover{border-color:var(--color-primary);color:var(--color-primary)}.section-title{font-size:2rem;font-weight:700;margin-bottom:3rem;text-align:center;position:relative;letter-spacing:.02em}.section-title:after{content:"";display:block;width:60px;height:3px;background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));margin:1rem auto 0}.section-subtitle{text-align:center;color:var(--color-text-muted);margin:-1.5rem auto 2.5rem;max-width:720px}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:7rem 2rem 6rem;background:linear-gradient(160deg,#05070bf2,#0a111ef2)}.hero-content{width:100%;max-width:1200px;display:grid;gap:3.5rem}.hero-intro{display:grid;gap:1rem;justify-items:center;text-align:center}.hero-title{font-size:clamp(2.6rem,4vw,3.8rem);font-weight:800;margin-bottom:.25rem;background:linear-gradient(120deg,var(--color-text) 0%,#b7d6f3 60%,var(--color-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.35rem;font-weight:600;color:var(--color-secondary)}.hero-description{font-size:1.1rem;color:var(--color-text-muted);margin-bottom:2rem;line-height:1.8;max-width:680px}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.projects{padding:6rem 0;background:#090e16f5}.projects-category{margin-bottom:4rem}.category-title{font-size:1.25rem;font-weight:600;color:var(--color-text-muted);margin-bottom:1.5rem;padding-left:1rem;border-left:3px solid var(--color-primary);letter-spacing:.04em;text-transform:uppercase}.category-description{color:var(--color-text-muted);max-width:820px;margin-bottom:.75rem;line-height:1.75}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;align-items:stretch}.project-card{background:#0e1824b3;border:1px solid rgba(40,217,255,.18);border-radius:18px;transition:border-color .3s,transform .3s,box-shadow .3s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 18px 40px #05070b73;min-height:100%;transform-style:preserve-3d}.project-card:hover{border-color:#28d9ff99;transform:translateY(-6px);box-shadow:0 24px 50px #05070b8c}.project-card.is-morph-source-hidden{visibility:hidden;pointer-events:none}.project-card[data-type=ai]{border-color:#60f5c740}.project-card-trigger{width:100%;height:100%;border:none;background:transparent;padding:1.6rem;text-align:left;color:inherit;cursor:pointer;font-family:var(--font-sans);display:flex;flex-direction:column}.project-card-trigger:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:14px}.project-header{margin-bottom:1rem}.project-type{display:inline-block;padding:.25rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;border-radius:999px;color:#041017;margin-bottom:.75rem}.project-title{font-size:1.25rem;font-weight:700;color:var(--color-text)}.project-description{font-size:.9rem;color:var(--color-text-muted);margin-bottom:1rem}.project-open-hint{margin-top:auto;padding-top:1rem;font-size:.75rem;color:var(--color-primary);letter-spacing:.04em;text-transform:uppercase}.project-bullets{list-style:none;margin-bottom:1rem}.project-bullets li{font-size:.85rem;color:var(--color-text-muted);padding-left:1.25rem;position:relative;margin-bottom:.5rem}.project-bullets li:before{content:"›";position:absolute;left:0;color:var(--color-primary);font-family:var(--font-mono)}.project-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.stack-tag{font-size:.75rem;padding:.25rem .5rem;background:#0f1826cc;border:1px solid rgba(40,217,255,.2);border-radius:999px;color:var(--color-text-muted);font-family:var(--font-mono)}.project-links{display:flex;gap:.5rem}.project-modal-overlay{position:fixed;inset:0;background:#05070bc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:220;animation:project-modal-overlay-fade .2s ease}.project-modal-overlay.is-animating{pointer-events:none;-webkit-backdrop-filter:none;backdrop-filter:none}.project-morph-shell{--modal-final-width: min(920px, calc(100vw - 3rem) );--modal-final-height: min(88vh, calc(100vh - 3rem) );position:fixed;top:50%;left:50%;width:var(--modal-final-width);height:var(--modal-final-height);transform:translate(-50%,-50%);perspective:1800px;transform-origin:center center;will-change:transform;contain:layout paint style}.project-morph-shell.is-opening{animation:project-shell-open .54s cubic-bezier(.2,.75,.2,1) forwards}.project-morph-shell.is-closing{animation:project-shell-open .48s cubic-bezier(.3,.2,.3,1) reverse forwards}.project-morph-flipper{position:relative;width:100%;height:100%;transform-style:preserve-3d;will-change:transform}.project-morph-flipper.is-opening{animation:project-flip-open .54s cubic-bezier(.2,.75,.2,1) forwards}.project-morph-flipper.is-open{transform:rotateY(180deg)}.project-morph-flipper.is-closing{animation:project-flip-open .48s cubic-bezier(.3,.2,.3,1) reverse forwards}.project-morph-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:1px solid rgba(40,217,255,.32);border-radius:22px;box-shadow:0 35px 80px #0000008c;overflow:hidden;display:flex;flex-direction:column;transform:translateZ(0)}.project-morph-shell[data-type=ai] .project-morph-face{border-color:#60f5c74d}.project-morph-face-front{background:#0e1824f0;border-radius:18px}.project-morph-front-content{padding:1.6rem;height:100%;display:flex;flex-direction:column}.project-morph-face-back{transform:rotateY(180deg) translateZ(.1px);background:#0b111af5;padding:2rem;overflow-y:auto}.project-modal-close{position:absolute;top:.8rem;right:.8rem;width:2rem;height:2rem;border-radius:999px;border:1px solid rgba(40,217,255,.35);background:#0e1824d9;color:var(--color-text);font-size:1.3rem;line-height:1;cursor:pointer}.project-modal-close:hover{border-color:var(--color-primary);color:var(--color-primary)}.project-modal-description{font-size:.95rem;line-height:1.75;color:var(--color-text-muted);margin-bottom:1.25rem}.project-morph-face-back .project-bullets{margin-bottom:1.25rem}.project-modal-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1.25rem}.project-modal-image{background:#0e1824c7;border:1px solid rgba(40,217,255,.16);border-radius:14px;padding:.75rem}.project-modal-image img{width:100%;height:170px;object-fit:cover;border-radius:10px}.project-modal-image figcaption{margin-top:.6rem;font-size:.78rem;color:var(--color-text-muted)}.project-modal-placeholder{border:1px dashed rgba(40,217,255,.35);border-radius:14px;padding:1rem;color:var(--color-text-muted);font-size:.85rem;text-align:center;background:#0e182499}.project-morph-face-back .project-links{margin-top:1rem}@keyframes project-modal-overlay-fade{0%{opacity:0}to{opacity:1}}@keyframes project-shell-open{0%{transform:translate(-50%,-50%) translate(var(--morph-translate-x, 0px),var(--morph-translate-y, 0px)) scale(var(--morph-scale-x, 1),var(--morph-scale-y, 1))}to{transform:translate(-50%,-50%) translate(0) scale(1)}}@keyframes project-flip-open{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}to{transform:rotateY(180deg)}}.about{padding:6rem 0;background:#05070bf2}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.about-text p{margin-bottom:1rem;color:var(--color-text-muted);font-size:1rem;line-height:1.8}.about-text strong{color:var(--color-text)}.about-skills h3{font-size:1.25rem;margin-bottom:1.5rem;color:var(--color-text)}.skills-grid{display:grid;gap:1.5rem}.skill-group h4{font-size:.85rem;font-weight:600;color:var(--color-primary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{font-size:.8rem;padding:.35rem .75rem;background:#0f1826cc;border:1px solid rgba(40,217,255,.2);border-radius:999px;color:var(--color-text-muted)}.contact{padding:6rem 0;background:linear-gradient(180deg,#05070bf2,#0b111af2)}.contact-intro{text-align:center;font-size:1.1rem;color:var(--color-text-muted);margin-bottom:3rem}.contact-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;max-width:900px;margin:0 auto}.contact-card{display:flex;flex-direction:column;align-items:center;padding:2rem;background:#0e1824b3;border:1px solid rgba(40,217,255,.2);border-radius:18px;transition:all .3s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.contact-card:hover{border-color:#28d9ff99;transform:translateY(-6px);box-shadow:0 20px 40px #05070b80}.contact-icon{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin-bottom:.75rem}.contact-label{font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:.25rem}.contact-value{font-size:.8rem;color:var(--color-text-muted);text-align:center;word-break:break-all}@media(prefers-reduced-motion:reduce){body:after{animation:none}.project-card,.project-morph-shell,.project-morph-flipper,.project-modal-overlay{transition:none;animation:none}.project-morph-shell.is-opening,.project-morph-shell.is-closing{top:50%;left:50%;width:var(--modal-final-width);height:var(--modal-final-height);transform:translate(-50%,-50%)}.project-morph-flipper.is-opening,.project-morph-flipper.is-closing{transform:rotateY(180deg)}}@media(max-width:768px){.navbar{padding:1rem}.navbar-links{gap:1rem}.language-selector{margin-left:1rem}.language-btn{padding:.4rem .6rem}.current-lang{display:none}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.25rem}.hero-cta{flex-direction:column;align-items:center}.hero-content{gap:2rem}.about-content{grid-template-columns:1fr;gap:2rem}.projects-grid{grid-template-columns:1fr}.project-morph-shell{--modal-final-width: calc(100vw - 1.4rem) ;--modal-final-height: min(90vh, calc(100vh - 1.4rem) )}.project-morph-face-back{padding:1.35rem}.project-modal-gallery{grid-template-columns:1fr}.project-modal-close{top:.55rem;right:.55rem}.contact-links{grid-template-columns:1fr}}:root{--neural-offset: 270px;--neural-canvas-width: 270px}.neural-backbone{position:fixed;top:0;left:0;width:var(--neural-offset);height:100vh;display:flex;align-items:center;justify-content:center;pointer-events:auto;z-index:20;background:transparent;overflow:visible}.neural-canvas{width:var(--neural-canvas-width);height:100%;pointer-events:auto;background:transparent}.neural-canvas canvas{width:100%!important;height:100%!important;display:block;background:transparent}.neural-label{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:#28d9ff;background:#080e16bf;border:1px solid rgba(40,217,255,.35);padding:.2rem .6rem;border-radius:999px;font-family:JetBrains Mono,monospace}.main-content{padding-left:0}.hero{padding-left:calc(2rem + var(--neural-offset))}.projects,.about,.contact{padding-left:var(--neural-offset)}@media(min-width:901px){.navbar{padding-left:calc(2rem + var(--neural-offset))}}@media(max-width:900px){.neural-backbone{display:none}.main-content,.hero,.projects,.about,.contact{padding-left:0}}
