@import "https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700&family=DM+Sans:wght@400;500;700&display=swap";
:root,[data-theme=light]{--background:#fff;--surface:#f8fafc;--foreground:#1e293b;--text-primary:#1e293b;--text-secondary:#64748b;--accent:#6366f1;--accent-secondary:#ec4899;--border:#e2e8f0;--shadow:#0000001a;--container-width:1200px;--header-height:70px}[data-theme=dark]{--background:#0a0a0a;--surface:#141414;--foreground:#fff;--text-primary:#fff;--text-secondary:#a1a1aa;--accent:#6366f1;--accent-secondary:#ec4899;--border:#27272a;--shadow:#00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto;font-size:16px}body{background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:DM Sans,sans-serif;line-height:1.6;transition:background .3s,color .3s;overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-family:Sora,sans-serif;font-weight:700;line-height:1.2}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;height:auto}button,input,textarea{font-family:inherit;font-size:inherit;background:0 0;border:none;outline:none}.container{width:100%;max-width:var(--container-width);margin:0 auto;padding:0 20px}@media (min-width:640px){.container{padding:0 24px}}@media (min-width:1024px){.container{padding:0 32px}}.section{align-items:center;min-height:100vh;padding:60px 0;display:flex;position:relative}@media (min-width:768px){.section{padding:80px 0}}@media (min-width:1024px){.section{padding:100px 0}}.bg-gradient-primary{pointer-events:none;background:linear-gradient(135deg,#6366f10d,#ec48990d);position:absolute;inset:0}.bg-gradient-secondary{pointer-events:none;background:linear-gradient(#0000,#6366f108,#0000);position:absolute;inset:0}.bg-gradient-tertiary{pointer-events:none;background:linear-gradient(#0000,#6366f10d,#0000);position:absolute;inset:0}.glass{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#ffffffd9}[data-theme=dark] .glass{background:#141414d9}.theme-toggle{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex}.theme-toggle:hover{border-color:var(--accent);transform:scale(1.05)}.theme-toggle svg{width:20px;height:20px;color:var(--text-primary);transition:transform .3s}.theme-toggle:hover svg{color:var(--accent)}.gradient-text{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.header{z-index:50;transition:all .3s;position:fixed;top:0;left:0;right:0}.header-inner{height:var(--header-height);justify-content:space-between;align-items:center;display:flex}.header.scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#ffffffe6;padding:8px 0}[data-theme=dark] .header.scrolled{background:#141414e6}.logo{font-family:Sora,sans-serif;font-size:1.25rem;font-weight:700}.nav{display:none}@media (min-width:768px){.nav{align-items:center;gap:32px;display:flex}}.nav-link{color:var(--text-secondary);font-size:.875rem;transition:color .3s;position:relative}.nav-link:hover{color:var(--accent)}.nav-link:after{content:"";background:var(--accent);width:0;height:2px;transition:width .3s;position:absolute;bottom:-4px;left:0}.nav-link:hover:after{width:100%}.header-actions{align-items:center;gap:12px;display:flex}.theme-toggle{background:var(--surface);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-primary);border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .3s;display:flex}.theme-toggle:hover{background:var(--accent);border-color:var(--accent);color:#fff}@media (min-width:768px){.theme-toggle{display:flex}}.mobile-menu-btn{cursor:pointer;flex-direction:column;justify-content:space-between;width:24px;height:18px;display:flex}@media (min-width:768px){.mobile-menu-btn{display:none}}.mobile-menu-btn span{background:var(--text-primary);width:100%;height:2px;transition:all .3s}.mobile-menu-btn.active span:first-child{transform:rotate(45deg)translate(4px,4px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:last-child{transform:rotate(-45deg)translate(4px,-4px)}.mobile-menu{inset:0;top:var(--header-height);z-index:40;background:var(--background);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:20px;transition:background .3s;position:fixed}.mobile-menu a{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:16px 0;font-size:1.125rem;transition:color .3s;display:block}.mobile-menu a:hover{color:var(--accent)}.hero{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0}.hero-overlay{z-index:10;pointer-events:none;background:linear-gradient(#ffffff4d,#ffffff80,#fffffff2);position:absolute;inset:0}[data-theme=dark] .hero-overlay{background:linear-gradient(#0a0a0a66,#0a0a0a80,#0a0a0af2)}.hero-content{z-index:20;text-align:center;width:100%;padding:80px 20px;position:relative}.hero-subtitle{color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin-bottom:16px;font-size:.75rem}.hero-title{color:var(--text-primary);margin-bottom:16px;font-size:2.5rem}@media (min-width:640px){.hero-title{font-size:3rem}}@media (min-width:768px){.hero-title{font-size:3.5rem}}@media (min-width:1024px){.hero-title{font-size:4.5rem}}.hero-title span{display:block}.hero-title .gradient-text{margin-top:8px}.hero-description{color:var(--text-secondary);max-width:500px;margin:0 auto 32px;font-size:.875rem;line-height:1.7}@media (min-width:768px){.hero-description{max-width:600px;font-size:1rem}}.hero-cta{flex-direction:column;justify-content:center;gap:12px;display:flex}@media (min-width:640px){.hero-cta{flex-direction:row;gap:16px}}.btn{text-align:center;border-radius:9999px;min-width:150px;padding:12px 28px;font-size:.875rem;font-weight:500;transition:all .3s;display:inline-block}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{transform:scale(1.05);box-shadow:0 0 25px #6366f166}.btn-secondary{border:2px solid var(--border);color:var(--text-primary);background:0 0}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.hero-scroll{z-index:20;flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.hero-scroll span{color:var(--text-secondary);letter-spacing:.1em;font-size:.75rem}.hero-scroll-line{background:linear-gradient(to bottom, var(--accent), transparent);width:1px;height:40px}.about{background:var(--background);transition:background .3s;position:relative}.about-grid{grid-template-columns:1fr;align-items:center;gap:40px;display:grid}@media (min-width:1024px){.about-grid{grid-template-columns:1fr 1fr;gap:60px}}.about-label{color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin-bottom:12px;font-size:.75rem;display:block}.about-title{color:var(--text-primary);margin-bottom:24px;font-size:2rem}@media (min-width:768px){.about-title{font-size:2.5rem}}@media (min-width:1024px){.about-title{font-size:3rem}}.about-text{color:var(--text-secondary);margin-bottom:16px;font-size:.9375rem;line-height:1.7}.about-stats{flex-wrap:wrap;gap:24px;margin-top:32px;display:flex}.stat-item{text-align:center}.stat-number{font-size:2rem;font-weight:700;display:block}@media (min-width:768px){.stat-number{font-size:2.5rem}}.stat-label{color:var(--text-secondary);font-size:.75rem}.about-image-wrapper{justify-content:center;display:flex}.about-image{width:100%;max-width:280px;position:relative}@media (min-width:640px){.about-image{max-width:320px}}@media (min-width:1024px){.about-image{max-width:360px}}.about-image-inner{aspect-ratio:4/5;background:var(--surface);border:1px solid var(--border);border-radius:16px;justify-content:center;align-items:center;transition:background .3s,border-color .3s;display:flex;overflow:hidden}.about-image-placeholder{text-align:center;padding:24px}.about-image-avatar{background:#6366f11a;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;font-size:1.5rem;font-weight:700;display:flex}.about-image-text{color:var(--text-secondary);font-size:.875rem}.about-image-path{color:var(--text-secondary);margin-top:4px;font-size:.75rem}.about-image-border-1{border:2px solid var(--accent);z-index:-1;border-radius:16px;width:80px;height:80px;position:absolute;bottom:-16px;right:-16px}@media (min-width:768px){.about-image-border-1{width:100px;height:100px}}.about-image-border-2{border:2px solid var(--accent-secondary);z-index:-1;border-radius:16px;width:80px;height:80px;position:absolute;top:-16px;left:-16px}@media (min-width:768px){.about-image-border-2{width:100px;height:100px}}.skills{background:var(--background);transition:background .3s;position:relative}.skills-center{flex-direction:column;align-items:center;display:flex}.section-label{color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin-bottom:12px;font-size:.75rem;display:block}.section-title{color:var(--text-primary);text-align:center;margin-bottom:32px;font-size:2rem}@media (min-width:768px){.section-title{font-size:2.5rem}}@media (min-width:1024px){.section-title{font-size:3rem}}.skills-filter{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:40px;display:flex}.filter-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:9999px;padding:8px 20px;font-size:.875rem;transition:all .3s}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 20px #6366f14d}.skills-grid{grid-template-columns:repeat(2,1fr);justify-items:center;gap:24px;display:grid}@media (min-width:640px){.skills-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.skills-grid{grid-template-columns:repeat(4,1fr);gap:32px}}.skill-item{flex-direction:column;align-items:center;gap:12px;display:flex}.skill-circle{width:80px;height:80px;position:relative}@media (min-width:768px){.skill-circle{width:100px;height:100px}}.skill-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.skill-circle-bg{fill:none;stroke:var(--border);stroke-width:6px}.skill-circle-progress{fill:none;stroke:url(#skillGradient);stroke-width:6px;stroke-linecap:round}.skill-circle-value{color:var(--text-primary);justify-content:center;align-items:center;font-family:Sora,sans-serif;font-size:1rem;font-weight:700;display:flex;position:absolute;inset:0}@media (min-width:768px){.skill-circle-value{font-size:1.25rem}}.skill-name{color:var(--text-secondary);text-align:center;font-size:.75rem}@media (min-width:768px){.skill-name{font-size:.875rem}}.projects{background:var(--background);transition:background .3s;position:relative}.projects-grid{grid-template-columns:1fr;gap:24px;display:grid}@media (min-width:640px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.projects-grid{grid-template-columns:repeat(3,1fr);gap:28px}}.project-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:16px;transition:all .3s;overflow:hidden}.project-card:hover{border-color:var(--accent);box-shadow:0 10px 30px var(--shadow);transform:translateY(-4px)}.project-image{aspect-ratio:4/3;background:var(--background);justify-content:center;align-items:center;width:100%;height:250px;transition:background .3s;display:flex;position:relative;overflow:hidden}.project-image img{transition:transform .4s}.project-image-placeholder{text-align:center;padding:16px}.project-image-text{color:var(--text-secondary);font-size:.75rem}.project-image-path{color:var(--text-secondary);margin-top:4px;font-size:.625rem}.project-image-overlay{background:linear-gradient(to top, var(--background), transparent);pointer-events:none;position:absolute;inset:0}.project-content{z-index:10;margin-top:-60px;padding:20px;position:relative}.project-category{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;font-size:.6875rem;display:block}.project-title{color:var(--text-primary);margin-bottom:8px;font-size:1rem;transition:color .3s}.project-card:hover .project-title{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}@media (min-width:768px){.project-title{font-size:1.125rem}}.project-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:12px;font-size:.8125rem;line-height:1.5;display:-webkit-box;overflow:hidden}.project-tech{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.project-tech-tag{background:var(--background);border:1px solid var(--border);color:var(--text-secondary);border-radius:9999px;padding:4px 10px;font-size:.6875rem;transition:background .3s,border-color .3s}.project-link{color:var(--accent);align-items:center;gap:8px;font-size:.8125rem;font-weight:500;transition:gap .3s;display:inline-flex}.project-card:hover .project-link{gap:12px}.experience{background:var(--background);transition:background .3s;position:relative}.timeline{max-width:800px;margin:0 auto;position:relative}.timeline-line{background:linear-gradient(to bottom, var(--accent), var(--accent-secondary), transparent);width:2px;position:absolute;top:0;bottom:0;left:8px}@media (min-width:768px){.timeline-line{left:50%;transform:translate(-50%)}}.timeline-item{margin-bottom:40px;padding-left:40px;position:relative}@media (min-width:768px){.timeline-item{width:50%;padding-left:0}.timeline-item:nth-child(odd){text-align:right;padding-right:40px}.timeline-item:nth-child(2n){text-align:left;margin-left:50%;padding-left:40px}}.timeline-dot{background:var(--accent);z-index:10;border-radius:50%;width:12px;height:12px;position:absolute;top:4px;left:3px;box-shadow:0 0 15px #6366f14d}@media (min-width:768px){.timeline-dot{left:auto;right:-6px}.timeline-item:nth-child(2n) .timeline-dot{left:-6px;right:auto}}.timeline-year{color:var(--accent);margin-bottom:4px;font-size:.75rem;font-weight:500;display:block}.timeline-title{color:var(--text-primary);margin-bottom:4px;font-size:.9375rem}.timeline-company{color:var(--accent-secondary);margin-bottom:8px;font-size:.8125rem}.timeline-description{color:var(--text-secondary);margin-bottom:8px;font-size:.8125rem;line-height:1.5}.timeline-highlights{color:var(--text-secondary);font-size:.75rem}.timeline-highlights li{align-items:center;gap:8px;margin-bottom:4px;display:flex}@media (min-width:768px){.timeline-item:nth-child(odd) .timeline-highlights li{justify-content:flex-end}}.contact{background:var(--background);transition:background .3s;position:relative}.contact-grid{grid-template-columns:1fr;gap:40px;display:grid}@media (min-width:1024px){.contact-grid{grid-template-columns:2fr 3fr;gap:60px}}.contact-info h3{color:var(--text-primary);margin-bottom:12px;font-size:1.125rem}.contact-info p{color:var(--text-secondary);margin-bottom:24px;font-size:.9375rem;line-height:1.6}.contact-details{margin-bottom:24px}.contact-item{align-items:center;gap:16px;margin-bottom:16px;display:flex}.contact-icon{background:#6366f11a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.contact-icon svg{width:20px;height:20px;color:var(--accent)}.contact-label{color:var(--text-secondary);font-size:.75rem;display:block}.contact-value{color:var(--text-primary);font-size:.9375rem}.social-links{gap:12px;display:flex}.social-link{background:var(--surface);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .3s;display:flex}.social-link:hover{border-color:var(--accent);color:var(--accent)}.social-link svg{width:16px;height:16px;color:var(--text-primary)}.contact-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);margin-left:4px;font-size:.875rem;transition:color .3s}.form-label.active{color:var(--accent)}.form-input,.form-textarea{background:var(--surface);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;padding:12px 16px;font-size:.9375rem;transition:all .3s}.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.form-textarea{resize:vertical;min-height:120px}.form-submit{background:var(--accent);color:#fff;cursor:pointer;border-radius:8px;padding:12px 24px;font-weight:500;transition:all .3s}.form-submit:hover{transform:scale(1.02);box-shadow:0 0 25px #6366f166}.footer{border-top:1px solid var(--border);background:var(--background);padding:32px 0;transition:background .3s,border-color .3s;position:relative}.footer-inner{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}@media (min-width:768px){.footer-inner{text-align:left;flex-direction:row;justify-content:space-between}}.footer-logo{color:var(--text-primary);font-family:Sora,sans-serif;font-size:1rem;font-weight:700}.footer-title{color:var(--text-secondary);margin-top:4px;font-size:.75rem}.footer-links{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.footer-link{color:var(--text-secondary);font-size:.75rem;transition:color .3s}.footer-link:hover{color:var(--accent)}.footer-social{gap:10px;display:flex}.footer-copyright{border-top:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;gap:8px;margin-top:24px;padding-top:24px;display:flex}@media (min-width:768px){.footer-copyright{flex-direction:row;justify-content:space-between}}.copyright-text{color:var(--text-secondary);font-size:.75rem}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse-glow{0%,to{opacity:.5}50%{opacity:1}}.animate-float{animation:6s ease-in-out infinite float}.animate-glow{animation:2s ease-in-out infinite pulse-glow}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::-webkit-selection{background:var(--accent);color:#fff}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}.block{display:block}.inline-block{display:inline-block}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-40{z-index:40}.z-50{z-index:50}.opacity-0{opacity:0}.opacity-100{opacity:1}.overflow-hidden{overflow:hidden}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:8px}.rounded-xl{border-radius:12px}.rounded-2xl{border-radius:16px}.border{border:1px solid var(--border)}.border-none{border:none}.transition-all{transition:all .3s}.cursor-pointer{cursor:pointer}.pointer-events-none{pointer-events:none}.loading-spinner{border:2px solid var(--accent);border-top-color:#0000;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.bg-surface{background:var(--surface)}.bg-background{background:var(--background)}.bg-accent{background:var(--accent)}.bg-accent\/20{background:#6366f11a}.text-accent{color:var(--accent)}.text-accent-secondary{color:var(--accent-secondary)}.text-text-primary{color:var(--text-primary)}.text-text-secondary{color:var(--text-secondary)}.border-border{border-color:var(--border)}.border-accent{border-color:var(--accent)}
