:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a26;--bg-card-hover:#22223a;--text-primary:#f0f0f5;--text-secondary:#8888a0;--text-tertiary:#5c5c7a;--accent:#6d5ae0;--accent-light:#8b7cf7;--accent-gradient:linear-gradient(135deg, #6d5ae0, #b86ad9);--accent-glow:#6d5ae04d;--border:#1e1e32;--border-hover:#3a3a5c;--radius:16px;--radius-sm:10px;--max-width:1120px;--nav-height:72px;--shadow:0 4px 30px #0000004d;--shadow-hover:0 8px 50px #00000080}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-height)}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.7}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}::selection{background:var(--accent);color:#fff}.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}section{padding:120px 0;position:relative}.section-title{text-align:center;letter-spacing:-.5px;margin-bottom:16px;font-size:2.5rem;font-weight:800}.section-subtitle{color:var(--text-secondary);text-align:center;max-width:560px;margin:0 auto 64px;font-size:1.1rem;line-height:1.8}.highlight,.gradient-text{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn{border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.3px;border:none;justify-content:center;align-items:center;gap:8px;padding:14px 32px;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 20px var(--accent-glow)}.btn-primary:hover{box-shadow:0 8px 35px var(--accent-glow);transform:translateY(-2px)}.btn-secondary{color:var(--text-primary);border:1.5px solid var(--border);background:0 0}.btn-secondary:hover{border-color:var(--accent);background:#6d5ae014;transform:translateY(-2px)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:all .4s;position:relative;overflow:hidden}.card:before{content:"";background:var(--accent-gradient);opacity:0;height:2px;transition:opacity .4s;position:absolute;top:0;left:0;right:0}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-hover);background:var(--bg-card-hover);transform:translateY(-6px)}.card:hover:before{opacity:1}.tag{color:var(--accent-light);letter-spacing:.2px;background:#6d5ae01a;border:1px solid #6d5ae033;border-radius:50px;padding:4px 14px;font-size:.8rem;font-weight:500;display:inline-block}@media (width<=768px){section{padding:80px 0}.section-title{font-size:1.8rem}.section-subtitle{margin-bottom:40px;font-size:1rem}.container{padding:0 20px}}.navbar{z-index:1000;height:var(--nav-height);transition:all .4s;position:fixed;top:0;left:0;right:0}.navbar.scrolled{-webkit-backdrop-filter:blur(20px)saturate(1.5);backdrop-filter:blur(20px)saturate(1.5);background:#0a0a0fd9;border-bottom:1px solid #1e1e3280}.navbar-container{max-width:var(--max-width);justify-content:space-between;align-items:center;height:100%;margin:0 auto;padding:0 24px;display:flex}.navbar-logo{color:var(--text-primary);letter-spacing:-1px;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Inter,monospace;font-size:1.3rem;font-weight:800;text-decoration:none;position:relative}.navbar-links{gap:8px;list-style:none;display:flex}.navbar-links a{color:var(--text-secondary);border-radius:8px;padding:8px 16px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s;position:relative}.navbar-links a:hover{color:var(--text-primary);background:#6d5ae014}.navbar-links a.active{color:var(--accent-light);background:#6d5ae01a}.progress-bar{z-index:1001;background:0 0;height:3px;position:fixed;top:0;left:0;right:0}.progress-bar-fill{background:var(--accent-gradient);height:100%;box-shadow:0 0 10px var(--accent-glow);transition:width .1s linear}.navbar-toggle{cursor:pointer;z-index:1001;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.toggle-bar{background:var(--text-primary);border-radius:2px;width:24px;height:2px;transition:all .3s;display:block}.toggle-bar.open:first-child{transform:rotate(45deg)translate(5px,5px)}.toggle-bar.open:nth-child(2){opacity:0;transform:translate(-10px)}.toggle-bar.open:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.hero{align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero-bg{position:absolute;inset:0;overflow:hidden}.hero-bg:before{content:"";background:radial-gradient(circle,#6d5ae01f,#0000 70%);border-radius:50%;width:600px;height:600px;animation:8s ease-in-out infinite float;position:absolute;top:-200px;right:-100px}.hero-bg:after{content:"";background:radial-gradient(circle,#b86ad914,#0000 70%);border-radius:50%;width:400px;height:400px;animation:10s ease-in-out infinite reverse float;position:absolute;bottom:-100px;left:-100px}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}.hero-grid{width:100%;padding-top:var(--nav-height);grid-template-columns:1fr 1fr;align-items:center;gap:60px;display:grid}.hero-text{z-index:1;position:relative}.hero-greeting{color:var(--accent-light);background:#6d5ae01a;border:1px solid #6d5ae033;border-radius:50px;align-items:center;gap:8px;margin-bottom:24px;padding:8px 20px;font-size:1rem;font-weight:500;display:inline-flex}.hero-greeting-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.hero-name{letter-spacing:-1.5px;margin-bottom:8px;font-size:4rem;font-weight:900;line-height:1.05}.hero-role{color:var(--text-secondary);margin-bottom:24px;font-size:1.4rem;font-weight:400}.hero-description{color:var(--text-secondary);max-width:500px;margin-bottom:40px;font-size:1.1rem;line-height:1.8}.hero-actions{flex-wrap:wrap;gap:16px;display:flex}.hero-visual{z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.hero-image-wrapper{aspect-ratio:1;width:100%;max-width:400px;position:relative}.hero-image-ring{border:1px solid #6d5ae026;border-radius:50%;animation:20s linear infinite spin;position:absolute;inset:-20px}.hero-image-ring:nth-child(2){border-style:dashed;animation-duration:30s;animation-direction:reverse;inset:-40px}@keyframes spin{to{transform:rotate(360deg)}}.hero-image{object-fit:cover;border:3px solid var(--border);background:var(--bg-card);border-radius:50%;width:100%;height:100%;display:block;box-shadow:0 20px 60px #6d5ae033}.hero-image-placeholder{background:var(--bg-card);border:3px solid var(--border);width:100%;height:100%;color:var(--accent-light);background:linear-gradient(135deg,#1a1a26,#22223a);border-radius:50%;justify-content:center;align-items:center;font-size:5rem;font-weight:900;display:flex;box-shadow:0 20px 60px #6d5ae026}.hero-stats{flex-wrap:wrap;gap:48px;margin-top:48px;display:flex}.stat{flex-direction:column;align-items:flex-start;display:flex}.stat-number{background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-1px;-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:800;line-height:1}.stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-top:6px;font-size:.85rem;font-weight:500}.about-grid{grid-template-columns:1fr 1.5fr;align-items:start;gap:64px;display:grid}.about-image-wrapper{width:100%;max-width:380px;margin:0 auto;position:relative}.about-image{aspect-ratio:1;object-fit:cover;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg-card);width:100%;display:block}.about-image-placeholder{aspect-ratio:1;border-radius:var(--radius);background:var(--bg-card);border:2px solid var(--border);width:100%;color:var(--accent-light);background:linear-gradient(135deg,#1a1a26,#22223a);justify-content:center;align-items:center;font-size:4rem;font-weight:900;display:flex}.about-image-wrapper:after{content:"";border-radius:var(--radius);border:2px solid var(--accent);z-index:-1;opacity:.3;width:100%;height:100%;position:absolute;bottom:-12px;right:-12px}.about-text h3{margin-bottom:8px;font-size:1.6rem;font-weight:700}.about-role{color:var(--accent-light);margin-bottom:20px;font-size:1rem;font-weight:500}.about-text p{color:var(--text-secondary);margin-bottom:16px;font-size:1rem;line-height:1.8}.about-details{border-top:1px solid var(--border);grid-template-columns:1fr 1fr;gap:20px;margin-top:32px;padding-top:32px;display:grid}.detail{align-items:flex-start;gap:14px;display:flex}.detail-icon{border-radius:var(--radius-sm);background:#6d5ae01a;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.detail-info strong{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:.85rem;display:block}.detail-info p{color:var(--text-primary);margin:0;font-size:.95rem}.skills-vertical{flex-direction:column;gap:28px;max-width:800px;margin:0 auto;display:flex}.skill-category-vertical{padding:28px 32px}.skill-category-title{color:var(--accent-light);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:8px;margin-bottom:20px;font-size:1rem;font-weight:600;display:flex}.skill-category-title:after{content:"";background:var(--border);flex:1;height:1px}.skill-badges{flex-wrap:wrap;gap:12px;display:flex}.skill-badge{color:var(--accent-light);cursor:default;background:#6d5ae014;border:1px solid #6d5ae026;border-radius:50px;align-items:center;gap:8px;padding:8px 18px;font-size:.85rem;font-weight:500;transition:all .3s;display:inline-flex}.skill-badge:hover{border-color:var(--accent);background:#6d5ae02e;transform:translateY(-3px);box-shadow:0 6px 20px #6d5ae033}.skill-badge-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.skill-badge-icon svg{width:100%;height:100%}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid}.project-card{flex-direction:column;padding:28px;display:flex}.project-image-wrapper{border-radius:var(--radius-sm);background:var(--bg-card);width:100%;margin-bottom:20px;overflow:hidden}.project-image{object-fit:cover;border-radius:var(--radius-sm);width:100%;height:180px;transition:transform .5s;display:block}.project-card:hover .project-image{transform:scale(1.05)}.project-image-wrapper{cursor:pointer;position:relative}.project-image-overlay{opacity:0;border-radius:var(--radius-sm);background:#00000080;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-image-overlay svg{color:#fff;transition:transform .3s;transform:scale(.8)}.project-image-wrapper:hover .project-image-overlay{opacity:1}.project-image-wrapper:hover .project-image-overlay svg{transform:scale(1)}.modal-backdrop{z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:24px;animation:.3s modalFadeIn;display:flex;position:fixed;inset:0}.modal-backdrop.closing{animation:.3s forwards modalFadeOut}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:700px;max-height:90vh;animation:.35s cubic-bezier(.16,1,.3,1) modalScaleIn;position:relative;overflow-y:auto}.modal-content.closing{animation:.3s forwards modalScaleOut}.modal-close{z-index:1;color:#fff;cursor:pointer;background:#0009;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{background:#ffffff26;transform:scale(1.1)}.modal-image-wrapper{border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:400px;overflow:hidden}.modal-image{object-fit:cover;width:100%;height:100%;display:block}.modal-body{padding:28px}.modal-tech{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.modal-title{letter-spacing:-.3px;margin-bottom:12px;font-size:1.5rem;font-weight:700}.modal-description{color:var(--text-secondary);margin-bottom:28px;font-size:.95rem;line-height:1.8}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes modalScaleOut{0%{opacity:1;transform:scale(1)translateY(0)}to{opacity:0;transform:scale(.9)translateY(20px)}}.project-tech{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.project-title{letter-spacing:-.3px;margin-bottom:12px;font-size:1.25rem;font-weight:700}.project-description{color:var(--text-secondary);flex:1;margin-bottom:24px;font-size:.92rem;line-height:1.7}.project-links{flex-wrap:wrap;gap:12px;display:flex}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border);background:0 0;gap:8px}.btn-ghost:hover{color:var(--accent-light);border-color:var(--accent);background:#6d5ae00f;transform:translateY(-2px)}.btn-sm{padding:10px 22px;font-size:.85rem}.typing-cursor{color:var(--accent-light);margin-left:2px;font-weight:100;animation:.8s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.timeline{max-width:700px;margin:0 auto;padding-left:36px;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), transparent);width:2px;position:absolute;top:0;bottom:0;left:14px}.timeline-item{margin-bottom:32px;position:relative}.timeline-dot{background:var(--bg-primary);border:3px solid var(--accent);z-index:1;width:16px;height:16px;box-shadow:0 0 20px var(--accent-glow);border-radius:50%;position:absolute;top:28px;left:-30px}.timeline-content{padding:28px}.timeline-year{color:var(--accent-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:.8rem;font-weight:600;display:block}.timeline-type{letter-spacing:.3px;border-radius:50px;margin-bottom:8px;padding:2px 12px;font-size:.75rem;font-weight:600;display:inline-block}.timeline-type.work{color:var(--accent-light);background:#6d5ae01a;border:1px solid #6d5ae033}.timeline-type.education{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.timeline-title{margin-bottom:4px;font-size:1.15rem;font-weight:700}.timeline-institution{color:var(--text-tertiary);margin-bottom:12px;font-size:.9rem;font-weight:500}.timeline-description{color:var(--text-secondary);font-size:.9rem;line-height:1.7}.freelance-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px;display:grid}.freelance-card{text-align:center;padding:40px 28px}.freelance-icon{color:var(--accent-light);background:#6d5ae014;border-radius:16px;margin-bottom:20px;padding:16px;display:inline-flex}.freelance-title{margin-bottom:12px;font-size:1.15rem;font-weight:700}.freelance-description{color:var(--text-secondary);font-size:.9rem;line-height:1.7}.freelance-cta{text-align:center;background:var(--accent-gradient);border-radius:var(--radius);padding:56px 40px;position:relative;overflow:hidden}.freelance-cta:before{content:"";background:radial-gradient(circle at 30%,#ffffff1a,#0000 60%);position:absolute;inset:0}.freelance-cta>*{z-index:1;position:relative}.freelance-cta p{color:#fff;margin-bottom:24px;font-size:1.3rem;font-weight:600}.freelance-cta .btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:#ffffff26;border:1px solid #ffffff40}.freelance-cta .btn:hover{background:#ffffff40;box-shadow:0 8px 30px #0000004d}.contact-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.contact-card{text-align:center;color:inherit;flex-direction:column;align-items:center;gap:12px;padding:36px 24px;text-decoration:none;display:flex}.contact-icon{color:var(--accent-light);background:#6d5ae01a;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;transition:all .3s;display:flex}.contact-card:hover .contact-icon{background:var(--accent-gradient);color:#fff;transform:scale(1.1)}.contact-card h3{font-size:1rem;font-weight:600}.contact-card p{color:var(--text-tertiary);font-size:.85rem}.contact-layout{grid-template-columns:1.5fr 1fr;align-items:start;gap:32px;display:grid}.contact-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.form-group input,.form-group textarea{background:var(--bg-primary);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;padding:14px 16px;font-family:inherit;font-size:.95rem;transition:all .3s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6d5ae026}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.contact-sidebar{flex-direction:column;gap:16px;display:flex}.contact-card-sm{color:inherit;align-items:center;gap:16px;padding:20px;text-decoration:none;transition:all .3s;display:flex}.contact-card-sm:hover{border-color:var(--accent);transform:translate(4px)}.contact-icon-sm{border-radius:var(--radius-sm);width:48px;height:48px;color:var(--accent-light);background:#6d5ae01a;flex-shrink:0;justify-content:center;align-items:center;transition:all .3s;display:flex}.contact-card-sm:hover .contact-icon-sm{background:var(--accent-gradient);color:#fff}.contact-card-sm strong{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:.85rem;display:block}.contact-card-sm p{color:var(--text-primary);margin:0;font-size:.95rem}.filter-bar{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:40px;display:flex}.filter-btn{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50px;padding:10px 24px;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .3s}.filter-btn:hover{border-color:var(--accent);color:var(--accent-light)}.filter-btn.active{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px var(--accent-glow);border-color:#0000}.timeline-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}.footer{border-top:1px solid var(--border);padding:32px 0}.footer-content{color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.footer-links{gap:24px;display:flex}.footer-links a{color:var(--text-tertiary);text-decoration:none;transition:color .3s}.footer-links a:hover{color:var(--accent-light)}@media (width<=1024px){.hero-grid{text-align:center;grid-template-columns:1fr;gap:40px}.hero-description{margin:0 auto 40px}.hero-actions,.hero-stats{justify-content:center}.hero-image-wrapper{max-width:300px;margin:0 auto}.hero-name{font-size:3rem}.hero-role{font-size:1.2rem}.hero-visual{order:-1}.skills-vertical{max-width:100%}.skill-category-vertical{padding:24px}.contact-grid{grid-template-columns:repeat(2,1fr)}.contact-layout,.about-details{grid-template-columns:1fr}}.reveal{opacity:0;transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94);transform:translateY(40px)}.reveal.revealed{opacity:1;transform:translateY(0)}@media (width<=768px){.navbar-links{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);opacity:0;pointer-events:none;background:#0a0a0ffa;flex-direction:column;justify-content:center;align-items:center;gap:12px;transition:all .4s;position:fixed;inset:0;transform:translateY(-100%)}.navbar-links.active{opacity:1;pointer-events:all;transform:translateY(0)}.navbar-links a{padding:12px 32px;font-size:1.2rem}.navbar-toggle{display:flex}.hero-name{font-size:2.4rem}.hero-image-wrapper{max-width:240px}.hero-stats{gap:32px}.stat-number{font-size:1.8rem}.about-grid{grid-template-columns:1fr;gap:40px}.skills-vertical{gap:20px}.skill-category-vertical{padding:20px}.projects-grid,.freelance-grid{grid-template-columns:1fr}.freelance-cta{padding:40px 24px}.freelance-cta p{font-size:1.1rem}.contact-grid{grid-template-columns:1fr}.footer-content{text-align:center;flex-direction:column;gap:12px}.timeline{padding-left:24px}}
