:root{--color-primary: #2563eb;--color-primary-light: #3b82f6;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-card: #ffffff;--color-border: #e5e7eb;--color-accent: #10b981;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius: 12px;--radius-sm: 8px}[data-theme=dark]{--color-primary: #3b82f6;--color-primary-light: #60a5fa;--color-text: #f9fafb;--color-text-secondary: #9ca3af;--color-bg: #111827;--color-bg-secondary: #1f2937;--color-bg-card: #1f2937;--color-border: #374151;--color-accent: #10b981;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .5), 0 4px 6px -4px rgb(0 0 0 / .4)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}#app{width:100%}.container{max-width:1200px;margin:0 auto;padding:0 24px}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-light)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-text)}h1{font-size:3rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.875rem;letter-spacing:-.01em}h3{font-size:1.25rem}p{color:var(--color-text-secondary)}.section{padding:80px 0}.section-alt{background-color:var(--color-bg-secondary)}.section-title{text-align:center;margin-bottom:48px}.section-title h2{margin-bottom:12px}.section-title p{font-size:1.125rem;max-width:600px;margin:0 auto}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius-sm);font-weight:500;font-size:.9375rem;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-light);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:#fff}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.slide-in-left{opacity:0;transform:translate(-30px);transition:opacity .6s ease,transform .6s ease}.slide-in-left.visible{opacity:1;transform:translate(0)}.slide-in-right{opacity:0;transform:translate(30px);transition:opacity .6s ease,transform .6s ease}.slide-in-right.visible{opacity:1;transform:translate(0)}@media(max-width:768px){h1{font-size:2.25rem}h2{font-size:1.5rem}.section{padding:60px 0}.container{padding:0 16px}}.navbar[data-v-f5f905cb]{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:all .3s ease}.navbar.scrolled[data-v-f5f905cb]{background:var(--color-bg);box-shadow:var(--shadow-md);padding:12px 0}.navbar-content[data-v-f5f905cb]{display:flex;align-items:center;justify-content:space-between}.navbar-logo[data-v-f5f905cb]{font-size:1.5rem;font-weight:700;color:var(--color-text);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-links[data-v-f5f905cb]{display:flex;gap:32px}.navbar-links a[data-v-f5f905cb]{color:var(--color-text-secondary);font-weight:500;font-size:.9375rem;transition:color .2s ease}.navbar-links a[data-v-f5f905cb]:hover{color:var(--color-primary)}.navbar-actions[data-v-f5f905cb]{display:flex;align-items:center;gap:8px}.toggle-btn[data-v-f5f905cb]{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;background:var(--color-bg-secondary);color:var(--color-text);cursor:pointer;transition:all .2s ease;font-weight:600;font-size:.75rem}.toggle-btn[data-v-f5f905cb]:hover{background:var(--color-primary);color:#fff}.mobile-menu-btn[data-v-f5f905cb]{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;border:none;background:transparent;color:var(--color-text);cursor:pointer}@media(max-width:768px){.navbar-links[data-v-f5f905cb]{position:fixed;top:70px;left:0;right:0;background:var(--color-bg);flex-direction:column;padding:24px;gap:16px;box-shadow:var(--shadow-lg);transform:translateY(-100%);opacity:0;pointer-events:none;transition:all .3s ease}.navbar-links.open[data-v-f5f905cb]{transform:translateY(0);opacity:1;pointer-events:auto}.mobile-menu-btn[data-v-f5f905cb]{display:flex}}.hero[data-v-7ff1c964]{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px}[data-theme=light] .hero[data-v-7ff1c964]{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}[data-theme=dark] .hero[data-v-7ff1c964]{background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%)}.container[data-v-7ff1c964]{max-width:1200px;margin:0 auto;padding:0 24px;width:100%;position:relative;z-index:1}.hero-content[data-v-7ff1c964]{max-width:720px;opacity:0;transform:translateY(30px);transition:all .8s ease}.hero-content.visible[data-v-7ff1c964]{opacity:1;transform:translateY(0)}.hero-badge[data-v-7ff1c964]{display:inline-block;padding:8px 16px;background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:500;border-radius:100px;margin-bottom:24px}.hero-title[data-v-7ff1c964]{font-size:4rem;font-weight:700;letter-spacing:-.03em;margin-bottom:16px;background:linear-gradient(135deg,var(--color-text) 0%,var(--color-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-tagline[data-v-7ff1c964]{font-size:1.5rem;color:var(--color-text-secondary);margin-bottom:24px;font-weight:400}.hero-about[data-v-7ff1c964]{font-size:1.125rem;line-height:1.8;color:var(--color-text-secondary);margin-bottom:32px;max-width:600px}.hero-actions[data-v-7ff1c964]{display:flex;gap:16px;margin-bottom:48px;flex-wrap:wrap}.hero-social[data-v-7ff1c964]{display:flex;gap:16px}.hero-social a[data-v-7ff1c964]{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--color-bg-card);color:var(--color-text);box-shadow:var(--shadow-md);transition:all .3s ease;border:1px solid var(--color-border)}.hero-social a[data-v-7ff1c964]:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);color:var(--color-primary)}.hero-decoration[data-v-7ff1c964]{position:absolute;top:0;right:0;width:100%;height:100%;pointer-events:none}.decoration-circle[data-v-7ff1c964]{position:absolute;border-radius:50%;opacity:.1}.decoration-circle-1[data-v-7ff1c964]{width:600px;height:600px;background:var(--color-primary);top:-200px;right:-200px}.decoration-circle-2[data-v-7ff1c964]{width:400px;height:400px;background:var(--color-accent);bottom:-100px;right:200px}.decoration-circle-3[data-v-7ff1c964]{width:200px;height:200px;background:var(--color-primary);top:50%;right:100px}@media(max-width:768px){.hero[data-v-7ff1c964]{min-height:auto;padding:120px 0 80px}.hero-title[data-v-7ff1c964]{font-size:2.5rem}.hero-tagline[data-v-7ff1c964]{font-size:1.25rem}.hero-about[data-v-7ff1c964]{font-size:1rem}.hero-actions[data-v-7ff1c964]{flex-direction:column}.btn[data-v-7ff1c964]{width:100%;justify-content:center}}.skill-card[data-v-eaabe73b]{background:var(--color-bg-card);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all .3s ease}.skill-card[data-v-eaabe73b]:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-header[data-v-eaabe73b]{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.card-icon[data-v-eaabe73b]{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-icon svg[data-v-eaabe73b]{width:24px;height:24px}.card-title-group[data-v-eaabe73b]{flex:1}.card-title[data-v-eaabe73b]{font-size:1.125rem;font-weight:600;margin-bottom:4px}.card-description[data-v-eaabe73b]{font-size:.875rem;color:var(--color-text-secondary);margin:0}.skills-list[data-v-eaabe73b]{display:flex;flex-wrap:wrap;gap:10px}.skill-tag[data-v-eaabe73b]{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:100px;font-size:.875rem;border:1px solid;transition:all .2s ease}.skill-tag[data-v-eaabe73b]:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.skill-tag svg[data-v-eaabe73b]{flex-shrink:0}.skill-name[data-v-eaabe73b]{font-weight:500}.skill-years[data-v-eaabe73b]{font-size:.75rem;opacity:.7;font-weight:400}.skills[data-v-64b07115]{background:var(--color-bg)}.skills-grid[data-v-64b07115]{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px}@media(max-width:768px){.skills-grid[data-v-64b07115]{grid-template-columns:1fr}}.timeline[data-v-4777f18c]{position:relative;max-width:900px;margin:0 auto}.timeline[data-v-4777f18c]:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:2px;height:100%;background:var(--color-border)}.timeline-item[data-v-4777f18c]{position:relative;width:50%;padding:20px 40px;opacity:0;transform:translate(-30px);transition:all .6s ease}.timeline-item.right[data-v-4777f18c]{margin-left:50%;transform:translate(30px)}.timeline-item.visible[data-v-4777f18c]{opacity:1;transform:translate(0)}.timeline-item[data-v-4777f18c]:before{content:"";position:absolute;width:16px;height:16px;background:var(--color-primary);border:4px solid var(--color-bg);border-radius:50%;top:30px}.timeline-item.left[data-v-4777f18c]:before{right:-8px}.timeline-item.right[data-v-4777f18c]:before{left:-8px}.timeline-content[data-v-4777f18c]{background:var(--color-bg-card);padding:24px;border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.timeline-header[data-v-4777f18c]{margin-bottom:16px}.timeline-period[data-v-4777f18c]{display:inline-block;padding:4px 12px;background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:600;border-radius:100px;margin-bottom:8px}.timeline-role[data-v-4777f18c]{font-size:1.125rem;margin-bottom:4px}.timeline-company[data-v-4777f18c]{color:var(--color-primary);font-weight:500}.timeline-company-link[data-v-4777f18c]{display:inline-flex;align-items:center;gap:4px;transition:opacity .2s ease}.timeline-company-link[data-v-4777f18c]:hover{opacity:.8;text-decoration:underline}.timeline-company-link svg[data-v-4777f18c]{flex-shrink:0}.timeline-description[data-v-4777f18c]{font-size:.9375rem;margin-bottom:16px}.timeline-highlights[data-v-4777f18c]{list-style:none;margin-bottom:16px}.timeline-highlights li[data-v-4777f18c]{position:relative;padding-left:20px;font-size:.875rem;color:var(--color-text-secondary);margin-bottom:8px}.timeline-highlights li[data-v-4777f18c]:before{content:"→";position:absolute;left:0;color:var(--color-primary)}.timeline-technologies[data-v-4777f18c]{display:flex;flex-wrap:wrap;gap:8px}.tech-tag[data-v-4777f18c]{padding:4px 10px;background:var(--color-bg-secondary);color:var(--color-text-secondary);font-size:.75rem;border-radius:100px;font-weight:500}.education-section[data-v-4777f18c]{margin-top:80px}.education-title[data-v-4777f18c]{text-align:center;margin-bottom:32px;font-size:1.5rem}.education-grid[data-v-4777f18c]{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:700px;margin:0 auto}.education-card[data-v-4777f18c]{background:var(--color-bg-card);padding:24px;border-radius:var(--radius);border:1px solid var(--color-border);text-align:center}.education-period[data-v-4777f18c]{font-size:.875rem;color:var(--color-primary);font-weight:500}.education-degree[data-v-4777f18c]{font-size:1rem;margin:8px 0}.education-institution[data-v-4777f18c]{font-size:.875rem;color:var(--color-text-secondary)}@media(max-width:768px){.timeline[data-v-4777f18c]:before{left:20px}.timeline-item[data-v-4777f18c]{width:100%;padding-left:50px;padding-right:0}.timeline-item.right[data-v-4777f18c]{margin-left:0}.timeline-item[data-v-4777f18c]:before{left:12px!important;right:auto!important}}.projects-grid[data-v-068687f6]{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.project-card[data-v-068687f6]{background:var(--color-bg-card);border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);transition:all .3s ease}.project-card[data-v-068687f6]:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.project-image[data-v-068687f6]{height:160px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);padding:24px}.project-image img[data-v-068687f6]{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.project-placeholder[data-v-068687f6]{height:160px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-border) 100%);color:var(--color-text-secondary)}.project-content[data-v-068687f6]{padding:24px}.project-name[data-v-068687f6]{font-size:1.125rem;margin-bottom:8px}.project-description[data-v-068687f6]{font-size:.9375rem;margin-bottom:16px;line-height:1.6}.project-technologies[data-v-068687f6]{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tech-tag[data-v-068687f6]{padding:4px 10px;background:var(--color-bg-secondary);color:var(--color-text-secondary);font-size:.75rem;border-radius:100px;font-weight:500}.project-link[data-v-068687f6]{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary);font-weight:500;font-size:.9375rem}.project-link[data-v-068687f6]:hover{text-decoration:underline}.contact-wrapper[data-v-1a072255]{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;max-width:900px;margin:0 auto}.contact-info[data-v-1a072255]{display:flex;flex-direction:column;gap:24px}.contact-item[data-v-1a072255]{display:flex;align-items:flex-start;gap:16px}.contact-icon[data-v-1a072255]{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.contact-item h4[data-v-1a072255]{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:4px;font-weight:500}.contact-item a[data-v-1a072255],.contact-item span[data-v-1a072255]{color:var(--color-text);font-weight:500}.contact-social[data-v-1a072255]{display:flex;gap:12px;margin-top:16px}.social-link[data-v-1a072255]{width:48px;height:48px;border-radius:50%;background:var(--color-bg-card);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:all .2s ease}.social-link[data-v-1a072255]:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.contact-form[data-v-1a072255]{background:var(--color-bg-card);padding:32px;border-radius:var(--radius);border:1px solid var(--color-border)}.form-group[data-v-1a072255]{margin-bottom:20px}.form-group label[data-v-1a072255]{display:block;font-size:.875rem;font-weight:500;margin-bottom:8px;color:var(--color-text)}.form-group input[data-v-1a072255],.form-group textarea[data-v-1a072255]{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;background:var(--color-bg);color:var(--color-text);transition:border-color .2s ease}.form-group input[data-v-1a072255]:focus,.form-group textarea[data-v-1a072255]:focus{outline:none;border-color:var(--color-primary)}.form-group textarea[data-v-1a072255]{resize:vertical;min-height:120px}.submit-btn[data-v-1a072255]{width:100%;justify-content:center}.submit-btn[data-v-1a072255]:disabled{opacity:.7;cursor:not-allowed}.form-message[data-v-1a072255]{margin-top:16px;padding:12px;border-radius:var(--radius-sm);text-align:center;font-weight:500}.form-message.success[data-v-1a072255]{background:#d1fae5;color:#065f46}.form-message.error[data-v-1a072255]{background:#fee2e2;color:#991b1b}@media(max-width:768px){.contact-wrapper[data-v-1a072255]{grid-template-columns:1fr}}.footer[data-v-239ce60d]{background:var(--color-bg-secondary);padding:64px 0 32px;border-top:1px solid var(--color-border)}.footer-content[data-v-239ce60d]{display:flex;justify-content:space-between;align-items:flex-start;gap:32px;margin-bottom:48px}.footer-name[data-v-239ce60d]{font-size:1.25rem;font-weight:600;margin-bottom:4px}.footer-tagline[data-v-239ce60d]{color:var(--color-text-secondary);font-size:.9375rem;margin:0}.footer-links[data-v-239ce60d]{display:flex;flex-wrap:wrap;gap:24px}.footer-link[data-v-239ce60d]{display:flex;align-items:center;gap:8px;color:var(--color-text-secondary);font-size:.9375rem;transition:color .2s ease}.footer-link[data-v-239ce60d]:hover{color:var(--color-primary)}.footer-bottom[data-v-239ce60d]{padding-top:32px;border-top:1px solid var(--color-border);text-align:center}.footer-bottom p[data-v-239ce60d]{font-size:.875rem;color:var(--color-text-secondary);margin:0}@media(max-width:768px){.footer-content[data-v-239ce60d]{flex-direction:column;align-items:center;text-align:center}.footer-links[data-v-239ce60d]{justify-content:center}}.app[data-v-9e1211f6]{min-height:100vh}
