.preloader{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--bg-primary);display:flex;justify-content:center;align-items:center;z-index:9999;transition:opacity .5s ease,visibility .5s ease}.preloader.loaded{opacity:0;visibility:hidden}.loader{text-align:center}.loader-circle{width:48px;height:48px;border:var(--border-width) solid var(--border);background-color:var(--accent);box-shadow:var(--shadow-sm);border-radius:var(--radius-sm);margin:0 auto var(--space-5);animation:flip-loader 1.2s cubic-bezier(.25,1,.5,1) infinite}.loader-text{font-size:var(--text-sm);color:var(--text-primary);font-weight:800;font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase}@keyframes flip-loader{0%{transform:rotate(0);background-color:var(--accent)}50%{transform:rotate(180deg);background-color:var(--primary);box-shadow:-3px -3px 0 0 var(--border)}to{transform:rotate(360deg);background-color:var(--accent);box-shadow:var(--shadow-sm)}}.navbar{position:fixed;top:0;left:0;width:100%;background-color:var(--bg-primary);border-bottom:var(--border-width) solid var(--border);z-index:1000;transition:var(--transition)}.navbar.scrolled{background:var(--bg-primary);box-shadow:var(--shadow-sm)}.navbar .container{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-6)}.logo{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;transition:var(--transition)}.logo-icon-container{width:48px;height:48px;border-radius:var(--radius);overflow:hidden;border:var(--border-width) solid var(--border);display:flex;align-items:center;justify-content:center;background:var(--primary);box-shadow:2px 2px 0 0 var(--border)}.logo-icon{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}.logo:hover .logo-icon{transform:scale(1.08)}.logo-name{font-size:var(--text-xl);font-weight:800;font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.01em}.nav-menu{display:flex;align-items:center;gap:var(--space-6)}.nav-list{display:flex;gap:var(--space-3)}.nav-link{font-weight:700;font-size:var(--text-sm);color:var(--text-primary);font-family:var(--font-display);text-transform:uppercase;padding:var(--space-2) var(--space-4);border:var(--border-width) solid transparent;border-radius:var(--radius);transition:all var(--transition);display:inline-block}.nav-link:hover{color:#000;background-color:var(--primary-light);border-color:var(--border);transform:translate(-2px,-2px);box-shadow:2px 2px 0 0 var(--border)}.nav-link.active{color:#000!important;background-color:var(--accent);border-color:var(--border);box-shadow:3px 3px 0 0 var(--border);transform:translate(-2px,-2px)}.nav-actions{display:flex;align-items:center;gap:var(--space-4)}.theme-toggle{cursor:pointer;font-size:var(--text-lg);color:#000;background-color:var(--bg-secondary);border:var(--border-width) solid var(--border);border-radius:var(--radius);box-shadow:2px 2px 0 0 var(--border);width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}[data-theme=dark] .theme-toggle{color:#fff}.theme-toggle:hover{background:var(--accent);color:#000;transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}.theme-toggle:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--border)}.nav-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.hamburger{display:none;cursor:pointer;font-size:var(--text-2xl);color:var(--text-primary);padding:var(--space-2);border:var(--border-width) solid var(--border);border-radius:var(--radius);background-color:var(--bg-secondary);box-shadow:2px 2px 0 0 var(--border);transition:var(--transition)}.hamburger:hover{background:var(--accent);transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}@media(max-width:768px){.nav-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background:#0009;z-index:999;opacity:0;visibility:hidden;transition:all var(--transition-slow)}.nav-overlay.active{opacity:1;visibility:visible}.nav-menu{position:fixed;top:0;right:-100%;width:min(90vw,290px);height:100vh;z-index:1000;background:var(--bg-primary);border-left:var(--border-width) solid var(--border);flex-direction:column;align-items:flex-start;justify-content:center;padding:var(--space-20) var(--space-8);box-shadow:-10px 0 0 var(--border);transition:right var(--transition-slow) cubic-bezier(.77,.2,.05,1);gap:var(--space-10)}.nav-menu.active{right:0}.nav-list{flex-direction:column;align-items:flex-start;gap:var(--space-4);width:100%}.nav-item{width:100%;opacity:0;transform:translate(20px);transition:all var(--transition-slow)}.nav-menu.active .nav-item{opacity:1;transform:translate(0)}.nav-menu.active .nav-item:nth-child(1){transition-delay:.05s}.nav-menu.active .nav-item:nth-child(2){transition-delay:.1s}.nav-menu.active .nav-item:nth-child(3){transition-delay:.15s}.nav-menu.active .nav-item:nth-child(4){transition-delay:.2s}.nav-menu.active .nav-item:nth-child(5){transition-delay:.25s}.nav-menu.active .nav-item:nth-child(6){transition-delay:.3s}.nav-link{font-size:var(--text-lg);width:100%;display:block;padding:var(--space-2) var(--space-4)}.nav-actions{flex-direction:column;align-items:stretch;width:100%;gap:var(--space-4);margin-top:var(--space-6);padding-top:var(--space-6);border-top:var(--border-width) dashed var(--border);opacity:0;transform:translateY(20px);transition:all var(--transition-slow) .3s}.nav-menu.active .nav-actions{opacity:1;transform:translateY(0)}.theme-toggle{width:100%;height:42px}.hamburger{display:flex;align-items:center;justify-content:center;position:relative;z-index:1001}}.hero{min-height:100vh;padding:140px 0 100px;display:flex;align-items:center;position:relative;overflow:hidden;background-image:radial-gradient(rgba(0,0,0,.08) 1.5px,transparent 1.5px);background-size:24px 24px}[data-theme=dark] .hero{background-image:radial-gradient(rgba(255,255,255,.06) 1.5px,transparent 1.5px)}.hero:before{content:"";position:absolute;width:100px;height:100px;border:var(--border-width) solid var(--border);background-color:var(--accent);box-shadow:var(--shadow);border-radius:var(--radius-lg);top:15%;right:8%;z-index:0;animation:float 8s ease-in-out infinite}.hero:after{content:"";position:absolute;width:80px;height:80px;border:var(--border-width) solid var(--border);background-color:var(--secondary);box-shadow:var(--shadow);border-radius:50%;bottom:15%;left:5%;z-index:0;animation:float 10s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translateY(0) rotate(12deg)}50%{transform:translateY(-20px) rotate(25deg)}}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center;position:relative;z-index:1}.hero-text{max-width:560px}.greeting{font-size:var(--text-lg);color:var(--primary);font-weight:600;margin-bottom:var(--space-3);letter-spacing:.05em}.hero-title{font-size:clamp(2.5rem,5vw,3.75rem);font-weight:700;line-height:1.3;margin-bottom:var(--space-3);letter-spacing:-.03em}.hero-subtitle{font-size:clamp(1.5rem,3vw,2rem);color:var(--text-secondary);margin-bottom:var(--space-5);font-weight:500}.hero-brand-wrapper{display:flex;align-items:center;gap:var(--space-4);width:100%}.hero-titles-left{flex:1}.hero-avatar-mobile{display:none}.hero-description{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-8);line-height:1.7}.hero-buttons{display:flex;gap:var(--space-4);margin-bottom:var(--space-12);flex-wrap:wrap}.hero-stats{display:flex;gap:var(--space-4)}.stat{text-align:center;background-color:var(--accent);border:var(--border-width) solid var(--border);padding:var(--space-3) var(--space-5);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition);flex:1;min-width:100px}.stat:nth-child(2){background-color:var(--secondary)}.stat:nth-child(3){background-color:var(--primary-light)}.stat:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow)}.stat h3{font-size:var(--text-3xl);color:#000;font-weight:800;margin-bottom:var(--space-1);font-family:var(--font-display)}.stat p{color:#000;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.hero-image{display:flex;justify-content:center;position:relative}.image-wrapper{position:relative;width:100%;max-width:420px;z-index:1}.profile-img{border-radius:var(--radius-lg);border:var(--border-width) solid var(--border);box-shadow:var(--shadow-lg);background-color:var(--bg-secondary)}.image-badge{position:absolute;bottom:var(--space-4);right:-var(--space-2);background:var(--accent);border:var(--border-width) solid var(--border);color:#000;padding:var(--space-2) var(--space-4);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--space-2);z-index:2}.badge-content{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:700;color:#000;text-transform:uppercase}.scroll-indicator{position:absolute;bottom:var(--space-10);left:50%;transform:translate(-50%);text-align:center}.scroll-indicator a{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.mouse{width:26px;height:42px;border:2px solid var(--text-muted);border-radius:20px;position:relative}.wheel{width:4px;height:8px;background:var(--primary);border-radius:2px;position:absolute;top:8px;left:50%;transform:translate(-50%);animation:scroll 2s ease-in-out infinite}@keyframes scroll{0%,to{top:8px;opacity:1}50%{top:20px;opacity:.3}}.arrow span{display:block;width:8px;height:8px;border-bottom:2px solid var(--text-muted);border-right:2px solid var(--text-muted);transform:rotate(45deg);margin:-4px auto;animation:arrow 2s ease-in-out infinite}.arrow span:nth-child(2){animation-delay:-.2s}.arrow span:nth-child(3){animation-delay:-.4s}@keyframes arrow{0%,to{opacity:0}50%{opacity:1}}@media(max-width:1024px){.hero{padding:120px 0 80px}}@media(max-width:768px){.hero:before,.hero:after{display:none!important}.hero{min-height:auto;padding:110px 0 70px}.hero-content{grid-template-columns:1fr;text-align:center;gap:var(--space-12);align-items:center}.hero-text{max-width:100%;width:100%}.hero-title,.hero-subtitle,.hero-description{overflow-wrap:anywhere;word-break:break-word}.hero-title{font-size:clamp(2.25rem,6vw,3.25rem)}.hero-subtitle{font-size:clamp(1.25rem,3.5vw,1.85rem)}.hero-description{margin:0 auto;max-width:100%;line-height:1.7}.hero-image{width:100%;display:flex;justify-content:center;padding-top:var(--space-6);order:-1}.image-wrapper{margin:0 auto;width:100%;max-width:320px}.hero-buttons,.hero-stats{justify-content:center}.stat{text-align:center}.hero-image{width:100%}.image-wrapper{margin:0 auto;max-width:320px}.image-badge{right:var(--space-4)}.scroll-indicator{position:relative;bottom:auto;left:auto;transform:none;margin:var(--space-10) auto 0;display:flex;flex-direction:column;align-items:center}}@media(max-width:576px){.hero{padding:100px 0 50px}.hero-content{grid-template-columns:1fr;text-align:left;gap:var(--space-6)}.hero-text{text-align:left;width:100%}.hero-brand-wrapper{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);text-align:left;width:100%;margin-bottom:var(--space-4)}.hero-titles-left{flex:1}.hero-avatar-mobile{display:block;position:relative;width:88px;height:88px;flex-shrink:0}.avatar-img-mobile{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg);border:var(--border-width) solid var(--border);box-shadow:var(--shadow-sm)}.avatar-badge-mobile{position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;background-color:var(--accent-green, #34D399);border:var(--border-width) solid var(--border);border-radius:50%}.hero-title{font-size:clamp(1.8rem,7vw,2.5rem)}.hero-subtitle{font-size:clamp(1.1rem,4vw,1.4rem);margin-bottom:var(--space-3)}.hero-description{text-align:left;margin:0 0 var(--space-6) 0;font-size:var(--text-base)}.hero-buttons{flex-direction:row;justify-content:flex-start;gap:var(--space-3);margin-bottom:var(--space-8);width:100%}.hero-buttons .btn{flex:1;padding:var(--space-3) var(--space-2);font-size:var(--text-sm)}.hero-stats{flex-direction:row;justify-content:space-between;gap:var(--space-2);width:100%}.stat{padding:var(--space-2) var(--space-1);min-width:0}.hero-image{display:none!important}.scroll-indicator{margin:var(--space-6) auto 0}.mouse{display:none}}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}.about-image{position:relative}.about-image img{border-radius:var(--radius-lg);border:var(--border-width) solid var(--border);box-shadow:var(--shadow-lg);background-color:var(--bg-secondary)}.about-text h3{font-size:var(--text-2xl);margin-bottom:var(--space-5);font-weight:800;font-family:var(--font-display)}.about-text p{color:var(--text-secondary);margin-bottom:var(--space-4);line-height:1.75;font-size:var(--text-base)}.about-info{margin:var(--space-8) 0;display:grid;gap:var(--space-4)}.info-row{display:flex;gap:var(--space-4);flex-wrap:wrap}.info-item{flex:1;min-width:240px;background-color:var(--bg-secondary);border:var(--border-width) solid var(--border);padding:var(--space-3) var(--space-4);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;transition:transform var(--transition),box-shadow var(--transition)}.info-item:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}.info-label{font-weight:800;font-family:var(--font-display);color:var(--text-primary);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.05em}.info-value{color:var(--text-secondary);font-weight:600;font-size:var(--text-sm)}.about-buttons{display:flex;gap:var(--space-4);flex-wrap:wrap}@media(max-width:768px){.about-content{grid-template-columns:1fr;gap:var(--space-12)}.about-image{order:-1}.about-buttons{flex-direction:column}.info-row{flex-direction:column;gap:var(--space-4)}.info-item{min-width:auto}}.skills{padding:80px 0;overflow:hidden}.skills-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;margin-top:40px}.skill-category{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:35px 25px;border:var(--border-width) solid var(--border);box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.skill-category:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-lg)}.category-header{display:flex;align-items:center;gap:15px;margin-bottom:30px;padding-bottom:15px;border-bottom:var(--border-width) dashed var(--border)}.category-icon{width:48px;height:48px;background:var(--accent);color:#000;border:var(--border-width) solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:2px 2px 0 0 var(--border)}.skill-category:nth-child(2) .category-icon{background:var(--primary)}.skill-category:nth-child(3) .category-icon{background:var(--secondary)}.category-header h3{font-size:1.4rem;font-weight:800;font-family:var(--font-display);color:var(--text-primary);text-transform:uppercase}.skill-cloud{display:flex;flex-wrap:wrap;justify-content:center;gap:20px}.floating-skill{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;transform:scale(.8);transition:opacity .5s ease,transform .5s ease}.floating-skill.visible{opacity:1;transform:scale(1);animation:float var(--float-duration, 4s) ease-in-out infinite}.floating-skill .skill-icon{width:60px;height:60px;background:var(--bg-secondary);border:var(--border-width) solid var(--border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--text-primary)!important;transition:var(--transition);box-shadow:var(--shadow-sm)}.floating-skill:hover .skill-icon{background:var(--accent);color:#000!important;transform:translateY(-5px) rotate(3deg);box-shadow:var(--shadow)}.floating-skill:nth-child(2n):hover .skill-icon{background:var(--primary-light);transform:translateY(-5px) rotate(-3deg)}.floating-skill:nth-child(3n):hover .skill-icon{background:var(--secondary);color:#fff!important}.skill-name-floating{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-align:center;pointer-events:none;opacity:.9;text-transform:uppercase;letter-spacing:.02em}.floating-skill:hover .skill-name-floating{opacity:1;color:var(--text-primary)}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}[data-theme=dark] .floating-skill .skill-icon{background:var(--bg-tertiary)}@media(max-width:768px){.skills-container{grid-template-columns:1fr;gap:25px}.skill-cloud{gap:15px}.floating-skill .skill-icon{width:50px;height:50px;font-size:1.5rem}}.projects-filter{display:flex;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-12);flex-wrap:wrap}.filter-btn{padding:var(--space-2) var(--space-5);background-color:var(--bg-secondary);border:var(--border-width) solid var(--border);border-radius:var(--radius-full);font-weight:800;font-size:var(--text-sm);cursor:pointer;transition:var(--transition);font-family:var(--font-display);color:var(--text-primary);box-shadow:var(--shadow-sm);text-transform:uppercase}.filter-btn.active,.filter-btn:hover{background-color:var(--accent);color:#000;transform:translate(-2px,-2px);box-shadow:var(--shadow)}.filter-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-8);margin-bottom:var(--space-12)}.project-card{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:var(--border-width) solid var(--border);transition:transform var(--transition),box-shadow var(--transition)}.project-card:hover{transform:translate(-6px,-6px);box-shadow:var(--shadow-lg)}.project-image{position:relative;height:220px;overflow:hidden;border-bottom:var(--border-width) solid var(--border)}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.project-card:hover .project-image img{transform:scale(1.04)}.project-overlay{position:absolute;inset:0;background:#ffde4df2;display:flex;justify-content:center;align-items:center;opacity:0;transition:opacity var(--transition-slow)}[data-theme=dark] .project-overlay{background:#ff6b6bf2}.project-card:hover .project-overlay{opacity:1}.overlay-content{display:flex;gap:var(--space-4)}.project-link{width:48px;height:48px;background-color:var(--bg-secondary);border:var(--border-width) solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#000;font-size:var(--text-lg);transition:var(--transition);box-shadow:var(--shadow-sm)}.project-link:hover{background-color:var(--primary);color:#000;transform:translate(-2px,-2px);box-shadow:var(--shadow)}.project-info{padding:var(--space-6);background-color:var(--bg-secondary)}.project-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.project-category{font-size:var(--text-xs);font-weight:800;color:var(--primary);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-display)}.project-date{font-size:var(--text-sm);color:var(--text-muted);font-weight:700}.project-title{font-size:var(--text-xl);font-weight:800;margin-bottom:var(--space-3);line-height:1.3;color:var(--text-primary);font-family:var(--font-display)}.project-description{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-4);line-height:1.6}.project-tech{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tech-tag{background-color:var(--bg-tertiary);color:var(--text-primary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:700;border:1.5px solid var(--border);text-transform:uppercase;letter-spacing:.02em}.projects-more{text-align:center}@media(max-width:768px){.projects-filter{justify-content:center}.projects-grid{grid-template-columns:1fr}}.timeline{position:relative;max-width:800px;margin:0 auto}.timeline:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:var(--border-width);background:var(--border);transform:translate(-50%)}.timeline-item{margin-bottom:60px;position:relative}.timeline-item:nth-child(odd){padding-right:calc(50% + 40px);text-align:right}.timeline-item:nth-child(2n){padding-left:calc(50% + 40px)}.timeline-content{background:var(--bg-secondary);padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:var(--border-width) solid var(--border);position:relative;transition:transform var(--transition),box-shadow var(--transition);text-align:left}.timeline-content:hover{box-shadow:var(--shadow-lg);transform:translate(-4px,-4px)}.timeline-content:before{content:"";position:absolute;top:28px;width:18px;height:18px;background-color:var(--accent);border:var(--border-width) solid var(--border);border-radius:var(--radius-sm);box-shadow:2px 2px 0 0 var(--border)}.timeline-item:nth-child(odd) .timeline-content:before{right:-49px}.timeline-item:nth-child(2n) .timeline-content:before{left:-49px}.timeline-header{margin-bottom:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.timeline-title{font-size:var(--text-xl);font-weight:800;font-family:var(--font-display);color:var(--text-primary);margin-bottom:0}.timeline-period{font-size:var(--text-xs);color:var(--primary);font-weight:800;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em}.timeline-company{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);font-weight:700}.timeline-description{color:var(--text-secondary);margin-bottom:var(--space-4);line-height:1.6;font-size:var(--text-sm)}.timeline-tech{display:flex;flex-wrap:wrap;gap:var(--space-2)}.timeline-tech .tech-tag{background-color:var(--bg-tertiary);color:var(--text-primary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:700;border:1.5px solid var(--border);text-transform:uppercase;letter-spacing:.02em}.timeline-item{display:flex;justify-content:flex-start}.timeline-item:nth-child(odd){justify-content:flex-end;padding-right:calc(50% + 40px)}.timeline-item:nth-child(2n){justify-content:flex-start;padding-left:calc(50% + 40px)}.timeline-content{max-width:360px;width:100%}@media(max-width:1024px){.timeline:before{left:24px}.timeline-item{padding-left:72px!important;padding-right:0!important;text-align:left!important}.timeline-content:before{left:-48px!important;right:auto!important;top:var(--space-8)}}@media(max-width:576px){.timeline:before{left:15px}.timeline-item{padding-left:48px!important}.timeline-content:before{left:-39px!important;top:var(--space-6)}}.contact-content{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-16);align-items:start}.contact-info{display:flex;flex-direction:column;gap:var(--space-6)}.info-card{display:flex;align-items:flex-start;gap:var(--space-5);padding:var(--space-6);background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:var(--border-width) solid var(--border);transition:transform var(--transition),box-shadow var(--transition)}.info-card:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-lg)}.info-icon{width:52px;height:52px;background:var(--accent);color:#000;border:var(--border-width) solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);flex-shrink:0;box-shadow:2px 2px 0 0 var(--border)}.info-card:nth-child(2) .info-icon{background:var(--primary-light)}.info-card:nth-child(3) .info-icon{background:var(--secondary);color:#fff}.info-content h3{font-size:var(--text-lg);font-weight:800;font-family:var(--font-display);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.02em}.info-content p{color:var(--text-secondary);font-size:var(--text-sm);font-weight:600}.social-links{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.social-link{width:48px;height:48px;background-color:var(--accent);border:var(--border-width) solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);color:#000;transition:transform var(--transition),box-shadow var(--transition),background-color var(--transition);box-shadow:var(--shadow-sm)}.social-link:hover{background-color:var(--primary-light);transform:translate(-3px,-3px);box-shadow:var(--shadow)}.social-link:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--border)}.contact-form{background:var(--bg-secondary);padding:var(--space-10);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:var(--border-width) solid var(--border)}.form-group{margin-bottom:var(--space-5)}.form-group input,.form-group textarea{width:100%;padding:var(--space-4);background-color:var(--bg-primary);border:var(--border-width) solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);box-shadow:var(--shadow-sm)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);font-weight:500}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);background-color:var(--bg-secondary);transform:translate(-3px,-3px);box-shadow:var(--shadow)}.form-group textarea{resize:vertical;min-height:140px}.form-status{margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius);font-size:var(--text-sm);font-weight:800;text-align:center;font-family:var(--font-display);text-transform:uppercase}.form-status.success{background-color:var(--accent-green);color:#000;border:var(--border-width) solid var(--border);box-shadow:var(--shadow-sm)}.form-status.error{background-color:var(--primary);color:#000;border:var(--border-width) solid var(--border);box-shadow:var(--shadow-sm)}.btn.loading{opacity:.7;cursor:not-allowed}@media(max-width:768px){.contact-content{grid-template-columns:1fr;gap:var(--space-12)}.contact-form{padding:var(--space-8)}}.footer{background-color:var(--bg-dark);color:#fff;padding:var(--space-16) 0 var(--space-8);margin-top:auto;position:relative;border-top:var(--border-width) solid var(--border)}.footer-reach-indicator{position:absolute;top:-3px;left:50%;transform:translate(-50%);width:100px;height:6px;background:var(--accent);border:var(--border-width) solid var(--border);border-radius:var(--radius-sm);opacity:1}.footer-content{text-align:center}.footer-logo{margin-bottom:var(--space-6)}.footer-logo .logo{justify-content:center;display:flex}.footer-logo .logo-icon-container{border-color:#fff;box-shadow:2px 2px 0 0 var(--primary)}.footer-text{max-width:480px;margin:0 auto var(--space-8);color:#ffffffd9;line-height:1.7;font-size:var(--text-sm);font-weight:500}.footer-links{display:flex;justify-content:center;gap:var(--space-6);margin-bottom:var(--space-8);flex-wrap:wrap}.footer-links a{color:#fffc;font-weight:700;font-size:var(--text-sm);font-family:var(--font-display);text-transform:uppercase;transition:var(--transition);padding:var(--space-1) var(--space-3);border:2px solid transparent}.footer-links a:hover{color:var(--accent);border-bottom:2px solid var(--accent)}.footer-social{display:flex;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-12)}.footer-social a{width:44px;height:44px;background-color:var(--accent);border:var(--border-width) solid #FFFFFF;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);color:#000;transition:transform var(--transition),box-shadow var(--transition);box-shadow:3px 3px 0 0 var(--primary)}.footer-social a:hover{background-color:var(--primary-light);transform:translate(-3px,-3px);box-shadow:5px 5px 0 0 var(--primary)}.footer-social a:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--primary)}.footer-bottom{padding-top:var(--space-8);border-top:var(--border-width) dashed rgba(255,255,255,.2)}.copyright{color:#fff9;font-size:var(--text-xs);margin-bottom:var(--space-2);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.made-with{color:#fff9;font-size:var(--text-xs);display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.heart-icon{color:#f36}.code-icon{color:var(--accent)}.back-to-top{position:fixed;bottom:var(--space-8);right:var(--space-8);width:48px;height:48px;background-color:var(--accent);color:#000;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);opacity:0;visibility:hidden;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition-slow),visibility var(--transition-slow);z-index:999;cursor:pointer;border:var(--border-width) solid var(--border);outline:none;box-shadow:var(--shadow-sm)}.back-to-top.active{opacity:1;visibility:visible}.back-to-top:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow);background-color:var(--primary-light)}.back-to-top:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--border)}.music-player-container{position:fixed;bottom:20px;left:20px;z-index:999;display:flex;flex-direction:column-reverse;align-items:flex-start;gap:15px}.music-toggle-btn{width:48px;height:48px;border-radius:var(--radius);background:var(--accent);border:var(--border-width) solid var(--border);color:#000;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition),background-color var(--transition)}.music-toggle-btn:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow);background-color:var(--primary-light)}.music-toggle-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--border)}.music-toggle-btn.active{background:var(--accent-green, #34D399);color:#000}.spotify-embed-wrapper{width:300px;height:80px;background:#121212;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:var(--border-width) solid var(--border);animation:slideUp .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.music-player-container{bottom:80px;left:15px}.spotify-embed-wrapper{width:250px}}:root{--primary: #FF6B6B;--primary-dark: #E0484D;--primary-light: #FFA1A1;--secondary: #4D96FF;--accent: #FFDE4D;--accent-green: #34D399;--text-primary: #000000;--text-secondary: #1E1E1E;--text-muted: #4A4A4A;--bg-primary: #F4F4F0;--bg-secondary: #FFFFFF;--bg-tertiary: #E5E5DE;--bg-dark: #0A0A0A;--border: #000000;--border-width: 3px;--border-focus: #FF6B6B;--shadow-sm: 3px 3px 0px 0px var(--border);--shadow: 5px 5px 0px 0px var(--border);--shadow-md: 6px 6px 0px 0px var(--border);--shadow-lg: 8px 8px 0px 0px var(--border);--shadow-xl: 10px 10px 0px 0px var(--border);--glass-bg: #FFFFFF;--glass-border: #000000;--card-bg: #FFFFFF;--card-border: #000000;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--font-sans: "DM Sans", system-ui, sans-serif;--font-display: "Space Grotesk", system-ui, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--container: 1200px;--radius-sm: 2px;--radius: 4px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--transition: .1s cubic-bezier(.4, 0, .2, 1);--transition-slow: .2s cubic-bezier(.4, 0, .2, 1);--primary-color: var(--primary);--primary-dark-color: var(--primary-dark);--secondary-color: var(--secondary);--accent-color: var(--accent);--text-color: var(--text-primary);--text-light: var(--text-secondary);--bg-color: var(--bg-primary);--bg-light: var(--bg-secondary);--border-color: var(--border);--card-bg: var(--bg-secondary);--skill-item-bg: var(--bg-tertiary);--skill-item-hover-bg: var(--accent);--skill-icon-bg: var(--bg-secondary)}[data-theme=dark]{--primary: #FF6B6B;--primary-dark: #FFA1A1;--primary-light: #FF8B8B;--secondary: #4D96FF;--accent: #FFDE4D;--accent-green: #34D399;--text-primary: #FFFFFF;--text-secondary: #E5E5DE;--text-muted: #A3A3A3;--bg-primary: #0A0A0A;--bg-secondary: #121212;--bg-tertiary: #1C1C1C;--bg-dark: #000000;--border: #FFFFFF;--border-focus: #FF6B6B;--shadow-color: #000000;--shadow-sm: 3px 3px 0px 0px var(--shadow-color);--shadow: 5px 5px 0px 0px var(--shadow-color);--shadow-md: 6px 6px 0px 0px var(--shadow-color);--shadow-lg: 8px 8px 0px 0px var(--shadow-color);--shadow-xl: 10px 10px 0px 0px var(--shadow-color);--glass-bg: #121212;--glass-border: #FFFFFF;--card-bg: #121212;--card-border: #FFFFFF;--skill-item-bg: #1C1C1C;--skill-item-hover-bg: var(--accent);--skill-icon-bg: #121212}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--primary: #FF6B6B;--primary-dark: #FFA1A1;--text-primary: #FFFFFF;--text-secondary: #E5E5DE;--text-muted: #A3A3A3;--bg-primary: #0A0A0A;--bg-secondary: #121212;--bg-tertiary: #1C1C1C;--border: #FFFFFF;--card-bg: #121212;--skill-item-bg: #1C1C1C;--skill-item-hover-bg: var(--accent);--skill-icon-bg: #121212}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-padding-top:88px;overflow-x:hidden;max-width:100%}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);transition:background-color var(--transition),color var(--transition);overflow-x:hidden;max-width:100%}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:800;line-height:1.2;letter-spacing:-.02em}a{text-decoration:none;color:inherit;transition:var(--transition)}ul{list-style:none}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--space-6)}.section{padding:var(--space-20) 0}.bg-light{background-color:var(--bg-secondary)}.highlight{color:#000;background-color:var(--accent);padding:0 6px;border-radius:var(--radius-sm);display:inline-block}[data-theme=dark] .highlight{color:#000}.glass-card{background:var(--card-bg);border:var(--border-width) solid var(--border);box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.glass-card:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-lg)}.glass-card:active{transform:translate(2px,2px);box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius);font-weight:700;font-size:var(--text-base);cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background-color var(--transition);border:var(--border-width) solid var(--border);outline:none;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em}.primary-btn{background-color:var(--primary);color:#000;box-shadow:var(--shadow-sm)}.primary-btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow);background-color:var(--primary-light)}.primary-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 0 var(--border)}.secondary-btn{background-color:var(--accent);color:#000;box-shadow:var(--shadow-sm)}.secondary-btn:hover{background-color:var(--bg-secondary);color:#000;transform:translate(-2px,-2px);box-shadow:var(--shadow)}.secondary-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 0 var(--border)}.section-header{text-align:center;margin-bottom:var(--space-16)}.section-label{display:inline-block;font-size:var(--text-sm);font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-3)}.section-title{font-size:var(--text-4xl);margin-bottom:var(--space-4);font-weight:700}.section-subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:560px;margin:0 auto}@media(max-width:1024px){.section-title{font-size:var(--text-3xl)}}@media(max-width:768px){.section{padding:var(--space-16) 0}.section-header{margin-bottom:var(--space-12)}}@media(max-width:576px){.section-title{font-size:var(--text-2xl)}.container{padding:0 var(--space-4)}}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1;width:100%;overflow-x:hidden}.custom-cursor{position:fixed;top:0;left:0;width:10px;height:10px;background-color:var(--primary);border:1.5px solid #000000;border-radius:var(--radius-sm);pointer-events:none;z-index:9999;will-change:transform;transform:translateZ(0)}.cursor-follower{position:fixed;top:0;left:0;width:40px;height:40px;border:var(--border-width) solid #000000;border-radius:var(--radius);pointer-events:none;z-index:9998;transition:opacity .3s ease;box-shadow:2px 2px #00000026;will-change:transform;transform:translateZ(0)}@media(hover:hover)and (pointer:fine){body,a,button,[role=button],.magnetic{cursor:none}}@media(hover:none){.custom-cursor,.cursor-follower{display:none}body{cursor:auto}}@media(max-width:768px){.custom-cursor,.cursor-follower{display:none!important}body{cursor:auto!important}}.animate-in{opacity:0;transform:translateY(40px);transition:opacity var(--animate-duration, .8s) cubic-bezier(.4,0,.2,1),transform var(--animate-duration, .8s) cubic-bezier(.4,0,.2,1);transition-delay:var(--animate-delay, 0ms)}.animate-in-visible{opacity:1;transform:translateY(0)}.animate-in-fade-up{transform:translateY(40px)}.animate-in-fade-up.animate-in-visible{transform:translateY(0)}.animate-in-fade-down{transform:translateY(-40px)}.animate-in-fade-down.animate-in-visible{transform:translateY(0)}.animate-in-fade-right{transform:translate(-40px)}.animate-in-fade-right.animate-in-visible{transform:translate(0)}.animate-in-fade-left{transform:translate(40px)}.animate-in-fade-left.animate-in-visible{transform:translate(0)}.animate-in-zoom-in{transform:scale(.9)}.animate-in-zoom-in.animate-in-visible{transform:scale(1)}
