.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:2rem 1.5rem;overflow:hidden}.hero-bg{position:absolute;inset:0;pointer-events:none}.hero-particles{position:absolute;inset:0;z-index:0}.hero-particles canvas{position:absolute!important;inset:0}@media(prefers-reduced-motion:reduce){.hero-particles{display:none}}.hero-orb{position:absolute;border-radius:50%;filter:blur(80px)}.hero-orb-1{width:400px;height:400px;background:var(--accent);top:10%;right:10%;opacity:.35}.hero-orb-2{width:300px;height:300px;background:var(--purple);bottom:20%;left:5%;opacity:.25}.hero-orb-3{width:200px;height:200px;background:var(--orange);top:50%;left:50%;transform:translate(-50%,-50%);opacity:.15}.hero-content{position:relative;z-index:1;text-align:center;max-width:640px}.hero-greeting{font-size:1rem;font-weight:500;color:var(--text-muted);margin-bottom:.5rem;letter-spacing:.05em}.hero-name{font-size:clamp(2.5rem,8vw,4rem);font-weight:700;line-height:1.15;margin-bottom:.5rem;letter-spacing:-.02em}.hero-name-accent{background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-role{font-family:var(--font-mono);font-size:1rem;color:var(--text-muted);min-height:1.6em;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.25rem}.hero-role-label{color:var(--accent)}.typewriter-wrap{display:inline-block;text-align:left}.typewriter-line{display:inline-flex;align-items:center}.typewriter-line .cursor{display:inline-block;width:2px;height:1em;background:var(--accent);margin-left:2px;vertical-align:middle}.hero-tagline{font-size:1.05rem;color:var(--text-muted);margin-bottom:2rem;max-width:420px;margin-left:auto;margin-right:auto}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-family:var(--font-sans);font-weight:500;font-size:.95rem;cursor:pointer;border:none;transition:box-shadow .2s}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{box-shadow:0 0 24px var(--accent-glow)}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--text-muted);box-shadow:0 0 20px var(--accent-dim)}.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);color:var(--text-muted);font-size:1.25rem}.section{padding:5rem 1.5rem}.section-inner{max-width:720px;margin:0 auto}.section-title{font-size:1.5rem;font-weight:600;margin-bottom:2rem;display:flex;align-items:center;gap:.75rem}.section-num{font-family:var(--font-mono);font-size:.9rem;color:var(--accent);opacity:.9}.about-grid{display:grid;gap:1.25rem;margin-bottom:2.5rem}.about-card{position:relative;background:#12121aa6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius);padding:1.5rem 1.75rem;overflow:hidden;box-shadow:inset 0 1px #ffffff12,0 8px 32px #00000040}.about-card:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;border-radius:inherit}.about-card-glow{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--purple),transparent);opacity:.7;z-index:1}.about-card p{color:var(--text-muted);font-size:.98rem;line-height:1.7}.about-stats{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.stat-item{text-align:center;padding:1rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:100px;cursor:default}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--accent);font-family:var(--font-mono)}.stat-label{font-size:.8rem;color:var(--text-muted)}.skills-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.skill-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:999px;font-size:.9rem;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:box-shadow .2s}.skill-pill-icon{width:22px;height:22px;object-fit:contain;flex-shrink:0}.skill-frontend{border-color:#00d4aa4d;color:var(--accent)}.skill-backend{border-color:#a855f74d;color:var(--purple)}.skill-tooling{border-color:#f973164d;color:var(--orange)}.skill-design{border-color:#3b82f64d;color:#3b82f6}.contact-intro{color:var(--text-muted);margin-bottom:2rem;font-size:1rem}.contact-links{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:3rem}@media(max-width:520px){.contact-links{grid-template-columns:1fr}}.contact-link,.contact-link-copy{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-weight:500;min-width:0}.contact-link-copy{cursor:pointer;border:1px solid var(--border);font-family:inherit;font-size:1rem;text-align:left;transition:border-color .2s,box-shadow .2s}.contact-link-copy:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-dim)}.contact-link-copy:hover .contact-link-logo{color:var(--accent)}.contact-link-logo{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;color:var(--text-muted)}.contact-link:hover .contact-link-logo{color:var(--accent)}.contact-link-label{flex:1;min-width:0;font-size:.9rem}.contact-link:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-dim)}.contact-link-icon{color:var(--accent);font-size:1.1rem}.footer{text-align:center;font-size:.85rem;color:var(--text-muted)}.footer-dot{margin:0 .5rem;opacity:.5}.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;background:var(--border);z-index:100;transform-origin:left}.scroll-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--purple));transform-origin:left}.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:1rem 1.5rem;transition:background .3s,box-shadow .3s}.nav-scrolled{background:#0a0a0fbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border),0 4px 24px #00000026}[data-theme=light] .nav-scrolled{background:#f5f5f8d1}.nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;transition:opacity .2s}.nav-logo:hover{opacity:.85}.nav-logo svg{transition:filter .25s;flex-shrink:0}.nav-logo:hover svg{filter:drop-shadow(0 0 8px var(--accent-glow))}.nav-logo-text{font-weight:700;font-size:1.1rem;font-family:var(--font-mono);letter-spacing:.04em;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:none;gap:.25rem}@media(min-width:768px){.nav-links{display:flex}}.nav-link{padding:.5rem .75rem;font-size:.9rem;color:var(--text-muted);border-radius:var(--radius-sm);transition:color .2s,background .2s}.nav-link:hover,.nav-link-active{color:var(--accent)}.nav-link-active{background:var(--accent-dim)}.nav-actions{display:flex;align-items:center;gap:.75rem}.nav-lang-wrap{position:relative}.nav-lang-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .65rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.8rem;font-weight:500;cursor:pointer;transition:border-color .2s,box-shadow .2s}.nav-lang-btn:hover{border-color:var(--text-muted);box-shadow:0 0 12px var(--accent-dim)}.nav-lang-chevron{font-size:.65rem;opacity:.8}.nav-lang-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;padding:.35rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 10px 30px #00000040;z-index:60;display:flex;flex-direction:column}.nav-lang-dropdown-portal{z-index:60}.nav-lang-option{padding:.5rem .75rem;border:none;border-radius:6px;background:transparent;color:var(--text);font-size:.9rem;text-align:left;cursor:pointer;transition:background .2s,color .2s}.nav-lang-option:hover,.nav-lang-option.active{background:var(--accent-dim);color:var(--accent)}.nav-lang-backdrop{position:fixed;inset:0;z-index:55}.nav-theme-btn{width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:box-shadow .2s}.nav-theme-btn:hover{box-shadow:0 0 16px var(--accent-dim)}.nav-mobile-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:0;border:none;background:transparent;cursor:pointer}@media(min-width:768px){.nav-mobile-btn{display:none}}.nav-mobile-btn span{display:block;width:22px;height:2px;background:var(--text);border-radius:1px;transition:transform .3s,opacity .3s}.nav-mobile-btn span:nth-child(1){transform-origin:center}.nav-mobile-btn span.open:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-mobile-btn span:nth-child(2).open{opacity:0}.nav-mobile-btn span:nth-child(3){transform-origin:center}.nav-mobile-btn span.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-mobile-menu{position:fixed;inset:0;z-index:40;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:5rem 1.5rem 2rem}[data-theme=light] .nav-mobile-menu{background:#0003}.nav-mobile-links{display:flex;flex-direction:column;gap:.5rem;max-width:280px;margin:0 auto;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 20px 40px #0003}.nav-mobile-link{padding:.75rem 1rem;font-weight:500;color:var(--text);border-radius:var(--radius-sm);transition:background .2s,color .2s}.nav-mobile-link:hover,.nav-mobile-link.active{background:var(--accent-dim);color:var(--accent)}.projects-section-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem}.projects-layout{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:start}@media(max-width:900px){.projects-layout{grid-template-columns:1fr}}.websites-panel{background:#12121aa6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius);overflow:hidden;box-shadow:inset 0 1px #ffffff0f,0 4px 16px #0003;position:sticky;top:5rem}.websites-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--purple),var(--accent),transparent);opacity:.5}.websites-panel-header{padding:1.1rem 1.4rem;border-bottom:1px solid var(--border)}.websites-panel-title{font-size:.95rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:.5rem;margin:0}.websites-panel-icon{font-size:1rem}.websites-list{display:flex;flex-direction:column}.website-item{display:block;padding:1rem 1.4rem;border-bottom:1px solid var(--border);text-decoration:none;transition:background .2s}.website-item:last-child{border-bottom:none}.website-item:hover{background:var(--accent-dim)}.website-name{font-size:.9rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.website-desc{font-size:.8rem;color:var(--text-muted);line-height:1.5;margin:0 0 .4rem}.website-url{font-size:.75rem;color:var(--accent);font-family:var(--font-mono);opacity:.85}[data-theme=light] .websites-panel{background:#ffffffb3;border-color:#00000014}.projects-grid{display:grid;gap:1.5rem}.project-card{position:relative;background:#12121aa6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius);overflow:hidden;transition:box-shadow .2s,transform .2s;box-shadow:inset 0 1px #ffffff0f,0 4px 16px #0003}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--purple),transparent);opacity:.5;z-index:1}.project-card:after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.02;pointer-events:none;border-radius:inherit}.project-card:hover{box-shadow:0 12px 40px var(--accent-dim),inset 0 1px #ffffff1a}.project-card-inner{padding:1.5rem 1.75rem}.project-title{font-size:1.15rem;font-weight:600;margin-bottom:.5rem;color:var(--text)}.project-desc{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin-bottom:1rem}.project-tech{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem}.project-tech-tag{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:var(--surface);border:1px solid var(--border);overflow:hidden}.project-tech-tag img{width:20px;height:20px;object-fit:contain}.projects-loading{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.projects-loading-dot{display:inline-block;width:8px;height:8px;margin:0 4px;background:var(--accent);border-radius:50%;animation:projects-loading-bounce 1.4s ease-in-out infinite both}.projects-loading-dot:nth-child(2){animation-delay:.2s}.projects-loading-dot:nth-child(3){animation-delay:.4s}@keyframes projects-loading-bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.projects-loading p{margin-top:1rem;font-size:.9rem}.projects-error{color:var(--orange);text-align:center;padding:2rem}.project-links{display:flex;gap:1rem;flex-wrap:wrap}.project-link{font-size:.9rem;font-weight:500}.back-to-top{position:fixed;bottom:2rem;right:1.5rem;width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:1.25rem;cursor:pointer;box-shadow:0 4px 20px #00000026;z-index:30;display:flex;align-items:center;justify-content:center;transition:box-shadow .2s}.back-to-top:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 24px var(--accent-dim)}@media(max-width:640px){.hero-name{font-size:2.25rem}.section{padding:3.5rem 1rem}.about-stats{gap:1rem}.back-to-top{bottom:1.5rem;right:1rem;width:44px;height:44px}}.cursor-dot{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--accent);pointer-events:none;z-index:9999;box-shadow:0 0 8px var(--accent-glow);will-change:transform}.cursor-ring{position:fixed;top:0;left:0;width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(0,212,170,.5);pointer-events:none;z-index:9998;will-change:transform}@media(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}.timeline-container{display:flex;gap:0;position:relative}.timeline-line-track{position:relative;width:2px;background:var(--border);flex-shrink:0;margin-right:2rem;border-radius:1px}.timeline-line-fill{position:absolute;inset:0;background:linear-gradient(180deg,var(--accent),var(--purple),var(--orange));border-radius:1px;transform-origin:top}.timeline-items{flex:1;display:flex;flex-direction:column;gap:1.5rem}.timeline-item{position:relative;padding-bottom:.5rem}.timeline-dot{position:absolute;left:-2.375rem;top:1.1rem;width:12px;height:12px;border-radius:50%;flex-shrink:0;transform:translate(-50%)}.timeline-card{background:#12121aa6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.1rem 1.4rem;transition:box-shadow .2s;box-shadow:inset 0 1px #ffffff0d}.timeline-card:hover{box-shadow:0 4px 20px #0003,inset 0 1px #ffffff12}.timeline-year{font-family:var(--font-mono);font-size:.78rem;font-weight:600;letter-spacing:.03em;display:block;margin-bottom:.3rem}.timeline-title{font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:.2rem}.timeline-subtitle{font-size:.82rem;color:var(--text-muted);margin-bottom:.4rem}.timeline-desc{font-size:.88rem;color:var(--text-muted);line-height:1.6}[data-theme=light] .timeline-card{background:#ffffffb3;border-color:#00000014}@media(max-width:520px){.timeline-line-track{margin-right:1.25rem}.timeline-dot{left:-1.875rem;width:10px;height:10px}}.contact-form{margin-top:2rem}.contact-form-title{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:1.25rem;padding-top:1.5rem;border-top:1px solid var(--border)}.contact-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}@media(max-width:520px){.contact-form-grid{grid-template-columns:1fr}}.contact-form-field{display:flex;flex-direction:column;gap:.3rem}.contact-form-field-full{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.3rem}.contact-form-input,.contact-form-textarea{width:100%;padding:.7rem .9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-sans);font-size:.9rem;transition:border-color .2s,box-shadow .2s;outline:none}.contact-form-input:focus,.contact-form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.contact-form-input.error,.contact-form-textarea.error{border-color:var(--orange)}.contact-form-textarea{resize:vertical;min-height:110px}.contact-form-error{font-size:.76rem;color:var(--orange)}.contact-form-footer{display:flex;align-items:center;justify-content:flex-end;gap:1rem;flex-wrap:wrap}.contact-form-status{font-size:.88rem;flex:1}.contact-form-status.success{color:var(--accent)}.contact-form-status.error{color:var(--orange)}.contact-form-btn{padding:.7rem 1.5rem;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius-sm);font-family:var(--font-sans);font-weight:600;font-size:.9rem;cursor:pointer;transition:box-shadow .2s,opacity .2s;display:flex;align-items:center;gap:.5rem}.contact-form-btn:hover:not(:disabled){box-shadow:0 0 20px var(--accent-glow)}.contact-form-btn:disabled{opacity:.6;cursor:not-allowed}.contact-form-spinner{width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--bg: #0a0a0f;--bg-elevated: #12121a;--surface: #16161f;--border: rgba(255, 255, 255, .06);--text: #e8e8ed;--text-muted: #8b8b9a;--accent: #00d4aa;--accent-dim: rgba(0, 212, 170, .15);--accent-glow: rgba(0, 212, 170, .4);--purple: #a855f7;--purple-dim: rgba(168, 85, 247, .2);--orange: #f97316;--font-sans: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--radius: 16px;--radius-sm: 10px}[data-theme=light]{--bg: #f5f5f8;--bg-elevated: #ffffff;--surface: #ffffff;--border: rgba(0, 0, 0, .08);--text: #1a1a22;--text-muted: #5c5c6b;--accent: #059669;--accent-dim: rgba(5, 150, 105, .12);--accent-glow: rgba(5, 150, 105, .35);--purple: #7c3aed;--purple-dim: rgba(124, 58, 237, .15);--orange: #ea580c}[data-theme=light] .about-card,[data-theme=light] .project-card{background:#ffffffb3;border-color:#00000014;box-shadow:inset 0 1px #ffffffe6,0 4px 16px #0000000f}@media(pointer:fine){body,a,button,[role=button]{cursor:none}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color .2s,opacity .2s}a:hover{color:var(--text)}::selection{background:var(--accent-dim);color:var(--accent)}
