@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Syne:wght@400..800&display=swap";:root{--bg-dark: #000000;--bg-card: #0d0d0f;--bg-elevated: #16161a;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--accent: #3b82f6;--accent-hover: #60a5fa;--accent-soft: rgba(59, 130, 246, .2);--border: #27272a;--gradient-hero: linear-gradient(135deg, #000000 0%, #0a0a0a 50%, #000000 100%);--font-heading: "Syne", sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--radius: 12px;--radius-lg: 20px;--transition: .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-dark);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:700}a{color:inherit;text-decoration:none;transition:color var(--transition)}button{font-family:inherit;cursor:pointer}.section{max-width:1200px;margin:0 auto;padding:5rem 1.5rem}.section-title{font-size:clamp(2rem,5vw,3rem);margin-bottom:.5rem;letter-spacing:-.02em}.section-subtitle{color:var(--text-secondary);font-size:1rem;margin-bottom:3rem}.accent{color:var(--accent)}.animated-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}.animated-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(59,130,246,.2) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.2) 1px,transparent 1px);background-size:40px 40px;animation:gridScroll 15s linear infinite}.animated-bg-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(59,130,246,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.12) 1px,transparent 1px);background-size:80px 80px;animation:gridScroll 22s linear infinite reverse}@keyframes gridScroll{0%{background-position:0 0}to{background-position:40px 40px}}.animated-bg-particles{position:absolute;inset:0}.animated-bg-particles .particle{position:absolute;width:3px;height:24px;left:var(--x);top:-20px;background:linear-gradient(to bottom,transparent,rgba(59,130,246,.9),rgba(59,130,246,.5));box-shadow:0 0 10px #3b82f699;animation:particleFall 8s linear infinite;animation-delay:var(--delay)}@keyframes particleFall{0%{transform:translateY(0) scaleY(.3);opacity:0}5%{opacity:1}95%{opacity:.7}to{transform:translateY(100vh) scaleY(1);opacity:0}}.animated-bg-circuit{position:absolute;inset:0}.circuit-line{position:absolute;background:#3b82f626}.circuit-h{width:100%;height:1px;top:30%}.circuit-v{width:1px;height:100%;left:25%}.circuit-trace{position:absolute;width:280px;height:3px;top:30%;left:0;background:linear-gradient(90deg,transparent,rgba(59,130,246,1),transparent);box-shadow:0 0 30px #3b82f6e6,0 0 60px #3b82f680;animation:circuitTrace 4s linear infinite}@keyframes circuitTrace{0%{transform:translate(-100%)}to{transform:translate(100vw)}}.animated-bg-streams{position:absolute;inset:0;overflow:hidden}.animated-bg-streams .stream{position:absolute;width:2px;height:200%;background:linear-gradient(to bottom,transparent,rgba(59,130,246,.4),rgba(59,130,246,.3),transparent);left:20%;top:-50%;transform:rotate(-15deg)}.animated-bg-streams .stream:nth-child(2){left:50%;transform:rotate(-25deg)}.animated-bg-streams .stream:nth-child(3){left:80%;transform:rotate(-10deg)}.animated-bg-streams .stream:nth-child(1){animation:streamFlow1 5s linear infinite}.animated-bg-streams .stream:nth-child(2){animation:streamFlow2 6s linear infinite 2s}.animated-bg-streams .stream:nth-child(3){animation:streamFlow3 5.5s linear infinite 4s}@keyframes streamFlow1{0%{transform:rotate(-15deg) translateY(-50%)}to{transform:rotate(-15deg) translateY(0)}}@keyframes streamFlow2{0%{transform:rotate(-25deg) translateY(-50%)}to{transform:rotate(-25deg) translateY(0)}}@keyframes streamFlow3{0%{transform:rotate(-10deg) translateY(-50%)}to{transform:rotate(-10deg) translateY(0)}}.animated-bg-orbit{position:absolute;width:300px;height:300px;top:20%;right:15%;animation:orbitRotate 15s linear infinite}.orbit-dot{position:absolute;width:10px;height:10px;background:#3b82f6;border-radius:50%;box-shadow:0 0 20px #3b82f6e6,0 0 40px #3b82f680;top:50%;left:50%;transform:translate(-50%,-50%) translate(140px)}.animated-bg-orbit .orbit-dot:nth-child(2){transform:translate(-50%,-50%) rotate(120deg) translate(140px)}.animated-bg-orbit .orbit-dot:nth-child(3){transform:translate(-50%,-50%) rotate(240deg) translate(140px)}@keyframes orbitRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animated-bg-gradient{position:absolute;border-radius:50%;filter:blur(100px);opacity:.55}.animated-bg-gradient-1{width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,.45) 0%,transparent 70%);top:-15%;right:-5%;animation:orbMove1 12s ease-in-out infinite}.animated-bg-gradient-2{width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,.4) 0%,transparent 70%);bottom:-10%;left:-5%;animation:orbMove2 14s ease-in-out infinite}@keyframes orbMove1{0%,to{transform:translate(0)}25%{transform:translate(-40px,30px)}50%{transform:translate(30px,-20px)}75%{transform:translate(-20px,-40px)}}@keyframes orbMove2{0%,to{transform:translate(0)}33%{transform:translate(35px,-30px)}66%{transform:translate(-25px,25px)}}.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#000000e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background var(--transition)}.header-inner{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.logo{font-family:var(--font-heading);font-size:1.5rem;font-weight:700}.logo-accent{color:var(--accent)}.nav{display:flex;align-items:center;gap:2rem}.nav-link{font-size:.9rem;color:var(--text-secondary);font-weight:500}.nav-link:hover{color:var(--text-primary)}.btn-contact{background:var(--accent);color:#fff!important;padding:.6rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:.9rem}.btn-contact:hover{background:var(--accent-hover)}.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:.5rem}.mobile-toggle span{width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:var(--transition)}.mobile-toggle[aria-expanded=true] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-toggle[aria-expanded=true] span:nth-child(2){opacity:0}.mobile-toggle[aria-expanded=true] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media(max-width:900px){.nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--bg-elevated);flex-direction:column;align-items:flex-start;padding:5rem 2rem 2rem;gap:1.5rem;transition:right var(--transition);border-left:1px solid var(--border)}.nav-open{right:0}.btn-contact{display:none}.mobile-toggle{display:flex}}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden}.hero-bg{position:absolute;inset:0;background:transparent;z-index:0}.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1;padding-top:6rem}.hero-welcome{font-size:.75rem;letter-spacing:.2em;color:var(--accent);margin-bottom:1rem}.hero-title{font-size:clamp(2.5rem,5vw,4rem);line-height:1.1;margin-bottom:.25rem}.hero-name{background:linear-gradient(135deg,var(--accent),#0ea5e9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-role{font-size:clamp(1.25rem,2vw,1.5rem);color:var(--text-secondary);margin-bottom:1.5rem}.hero-desc{color:var(--text-secondary);max-width:480px;margin-bottom:2rem;font-size:1.05rem}.hero-social{display:flex;flex-direction:column;gap:.75rem}.social-label{font-size:.7rem;letter-spacing:.15em;color:var(--text-muted)}.social-label.mt{margin-top:1rem}.social-icons{display:flex;gap:1rem}.social-link{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.75rem;font-weight:600;color:var(--text-secondary)}.social-link:hover{border-color:var(--accent);color:var(--accent)}.stack-icons{display:flex;flex-wrap:wrap;gap:.75rem}.stack-icons span{padding:.4rem .9rem;background:var(--accent-soft);color:var(--accent);font-size:.85rem;font-weight:600;border-radius:6px}.hero-visual{display:flex;justify-content:center;align-items:center;padding-top:1.5rem}.hero-image-wrap{position:relative}.hero-image{width:380px;height:450px;object-fit:cover;object-position:center top;border-radius:var(--radius-lg);border:1px solid var(--border)}@media(max-width:900px){.hero-inner{grid-template-columns:1fr;text-align:center}.hero-desc{margin-left:auto;margin-right:auto}.hero-social{align-items:center}.social-icons,.stack-icons{justify-content:center}.hero-image{width:280px;height:340px;margin:0 auto}.hero-visual{padding-top:0}}.about{background:var(--bg-card)}.about-grid{display:grid;grid-template-columns:320px 1fr;gap:4rem;align-items:center}.about-image-frame{position:relative;padding:1rem}.about-image-frame:before{content:"";position:absolute;inset:0;border:2px solid var(--accent);border-radius:var(--radius-lg);opacity:.4}.about-image-photo{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:var(--radius);display:block;filter:grayscale(100%)}.about-text{color:var(--text-secondary);margin-bottom:1.25rem;max-width:560px}.btn-cv{display:inline-block;background:var(--accent);color:#fff!important;padding:.85rem 2rem;border-radius:var(--radius);font-weight:600;margin-top:.5rem}.btn-cv:hover{background:var(--accent-hover)}@media(max-width:768px){.about-grid{grid-template-columns:1fr;text-align:center}.about-image{max-width:280px;margin:0 auto}.about-text{margin-left:auto;margin-right:auto}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1.25rem}.skill-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition)}.skill-card:hover{border-color:var(--skill-color);transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.skill-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--skill-color) 20%,transparent);color:var(--skill-color);font-weight:700;font-size:1.25rem;border-radius:10px}.skill-name{font-size:.95rem;font-weight:600}.whatido{background:var(--bg-card)}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.service-card{padding:2rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition)}.service-card:hover{border-color:var(--accent);box-shadow:0 4px 24px var(--accent-soft)}.service-icon{font-size:2rem;display:block;margin-bottom:1rem}.service-title{font-size:1.2rem;margin-bottom:.75rem}.service-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}.project-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.project-image{aspect-ratio:16/10;background:var(--bg-dark)}.project-photo{width:100%;height:100%;object-fit:contain;display:block}.project-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-soft) 0%,rgba(14,165,233,.1) 100%)}.project-initial{font-size:4rem;font-weight:800;color:var(--accent);opacity:.5}.project-placeholder--title{background:var(--bg-dark)}.project-placeholder--hidden{display:none!important}.project-title-logo{font-family:var(--font-heading);font-size:2rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}.project-content{padding:1.5rem}.project-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.25rem}.project-category{font-size:.75rem;color:var(--accent);font-weight:600;letter-spacing:.1em;text-transform:uppercase}.project-badge{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:.25rem .5rem;border-radius:6px}.project-title{font-size:1.25rem;margin:.5rem 0}.project-desc{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.project-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.stack-tag{padding:.3rem .6rem;background:var(--bg-dark);font-size:.75rem;border-radius:6px;color:var(--text-secondary)}.project-actions{display:flex;flex-wrap:wrap;gap:1rem}.project-link{font-size:.9rem;font-weight:600;color:var(--accent)}.project-link:hover{text-decoration:underline}.resume{background:var(--bg-card)}.resume-tabs{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.resume-tab{padding:.75rem 1.5rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-weight:600;font-size:.95rem}.resume-tab:hover{color:var(--text-primary);border-color:var(--text-muted)}.resume-tab.active{background:var(--accent);border-color:var(--accent);color:#fff!important}.resume-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.resume-item{padding:2rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius)}.resume-period{display:inline-block;font-size:.85rem;color:var(--accent);font-weight:600;margin-bottom:.5rem}.resume-title{font-size:1.2rem;margin-bottom:.25rem}.resume-org{font-size:.9rem;color:var(--text-secondary);display:block;margin-bottom:.75rem}.resume-desc{color:var(--text-secondary);font-size:.95rem}.skills-resume{display:flex;flex-direction:column;gap:1rem}.skills-row{display:flex;flex-wrap:wrap;gap:.75rem}.skill-badge{padding:.6rem 1.2rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius);font-weight:600;font-size:.95rem}.skill-badge:hover{border-color:var(--accent);color:var(--accent)}.clients{background:var(--bg-card)}.rating-card{max-width:420px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2.75rem 2rem;background:linear-gradient(160deg,#3b82f624,#0d0d0ff2);border:1px solid rgba(59,130,246,.35);border-radius:var(--radius-lg);box-shadow:0 0 0 1px #3b82f62e inset,0 16px 40px #00000073;transition:var(--transition)}.rating-card:hover{transform:translateY(-4px);border-color:#3b82f6b3;box-shadow:0 0 0 1px #3b82f659 inset,0 18px 48px #3b82f633}.rating-badge{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--accent);background:#3b82f629;border:1px solid rgba(59,130,246,.35);padding:.35rem .7rem;border-radius:999px}.rating-ring{width:150px;height:150px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:conic-gradient(var(--accent) 0 316deg,rgba(255,255,255,.12) 316deg 360deg);position:relative;filter:drop-shadow(0 0 14px rgba(59,130,246,.35))}.rating-ring:after{content:"";position:absolute;inset:10px;border-radius:50%;background:#09090b;border:1px solid rgba(59,130,246,.25)}.rating-value{position:relative;z-index:1;font-size:2.25rem;font-weight:800;color:#e5edff;text-shadow:0 0 14px rgba(59,130,246,.35)}.rating-label{font-size:.95rem;font-weight:700;color:var(--text-secondary)}.rating-stars{display:flex;gap:.35rem;font-size:1.25rem;color:#fbbf24}.star-muted{color:#fbbf2459}.rating-note{text-align:center;font-size:.85rem;color:var(--text-muted);max-width:300px}.contact-grid{display:grid;grid-template-columns:340px 1fr;gap:4rem;align-items:start}.contact-visual{width:80px;height:80px;margin-bottom:1.5rem}.contact-visual svg{width:100%;height:100%;color:var(--accent)}.contact-details{margin-bottom:2rem}.contact-details p{margin-bottom:.75rem;color:var(--text-secondary)}.contact-details a{color:var(--accent)}.contact-details a:hover{text-decoration:underline}.contact-social{display:flex;gap:.75rem}.contact-social a{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.75rem;font-weight:600}.contact-social a:hover{border-color:var(--accent);color:var(--accent)}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.contact-form input,.contact-form textarea{padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:1rem}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-muted)}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent)}.contact-form textarea{resize:vertical;min-height:120px}.btn-send{background:var(--accent);color:#fff;padding:1rem 2rem;border:none;border-radius:var(--radius);font-weight:600;font-size:1rem}.btn-send:hover{background:var(--accent-hover)}@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}.footer{background:var(--bg-card);border-top:1px solid var(--border);padding:2rem 1.5rem}.footer-inner{max-width:1200px;margin:0 auto;text-align:center}.footer-text{font-size:.9rem;color:var(--text-muted);margin-bottom:.25rem}.footer-tagline{font-size:.8rem;color:var(--text-muted);opacity:.8}
