@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}:root{--bg-primary:#f5f5f7;--bg-card:#ffffff;--bg-card-alt:#f0f1f5;--bg-hero:linear-gradient(135deg, #667eea 0%, #764ba2 100%);--text-primary:#1a1a2e;--text-secondary:#4a4a6a;--text-muted:#7c7c9a;--accent:#667eea;--accent-2:#764ba2;--accent-soft:rgba(102, 126, 234, 0.08);--accent-soft-2:rgba(118, 75, 162, 0.08);--border:rgba(0, 0, 0, 0.06);--shadow:0 1px 2px rgba(0,0,0,0.04), 0 4px 16px rgba(0,0,0,0.06);--shadow-hover:0 8px 32px rgba(102, 126, 234, 0.15);--glass:rgba(255, 255, 255, 0.7);--radius:20px;--radius-sm:12px;--font:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;--transition:0.3s cubic-bezier(0.4, 0, 0.2, 1)}[data-theme=dark]{--bg-primary:#0a0a14;--bg-card:#14142a;--bg-card-alt:#1c1c3a;--bg-hero:linear-gradient(135deg, #4a5fd4 0%, #5e3d8f 100%);--text-primary:#eaeaff;--text-secondary:#b0b0d0;--text-muted:#6c6c8e;--accent:#8b9ff7;--accent-2:#a87cd4;--accent-soft:rgba(139, 159, 247, 0.1);--accent-soft-2:rgba(168, 124, 212, 0.1);--border:rgba(255, 255, 255, 0.06);--shadow:0 1px 2px rgba(0,0,0,0.2), 0 4px 16px rgba(0,0,0,0.3);--shadow-hover:0 8px 32px rgba(139, 159, 247, 0.2);--glass:rgba(20, 20, 42, 0.8)}*{margin:0;padding:0;box-sizing:border-box;cursor:none}.custom-cursor,.custom-cursor--trail{position:fixed;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%)}.custom-cursor{width:10px;height:10px;background:var(--accent);z-index:10000;transition:transform .1s ease,width .2s ease,height .2s ease}.custom-cursor--trail{width:28px;height:28px;border:1.5px solid var(--accent);z-index:9999;transition:transform .08s ease;opacity:.5}.custom-cursor--hover{width:16px;height:16px;background:#ff6b6b;box-shadow:0 0 12px rgba(255,107,107,.6)}.custom-cursor--trail--hover{width:44px;height:44px;border-color:#ff6b6b;border-width:2px;opacity:.8;box-shadow:0 0 16px rgba(255,107,107,.3)}@media (max-width:900px),(pointer:coarse){*{cursor:auto}.custom-cursor,.custom-cursor--trail{display:none}}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background var(--transition),color var(--transition)}.topbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:14px 28px;background:var(--glass);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:all var(--transition)}.topbar-name{font-size:.85rem;font-weight:700;margin-right:auto;opacity:0;transform:translateY(-8px);transition:opacity .3s ease,transform .3s ease;pointer-events:none}.topbar-name.visible{opacity:1;transform:translateY(0)}.topbar-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:24px;background:var(--bg-card);color:var(--text-primary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.topbar-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 2px 12px rgba(102,126,234,.15)}.topbar-btn svg{width:16px;height:16px}.bento{max-width:1200px;margin:0 auto;padding:88px 20px 60px;display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);transition:all var(--transition);opacity:0;transform:translateY(24px);position:relative;overflow:hidden}.card.visible{opacity:1;transform:translateY(0)}.card:hover{box-shadow:var(--shadow-hover)}.card.visible:hover,.card:hover{transform:translateY(-3px)}.card--hero{grid-column:span 8}.card--info,.card--photo{grid-column:span 4}.card--skills{grid-column:span 8}.card--certs,.card--education,.card--experience{grid-column:span 12}.card--references{grid-column:span 5}.card--contact{grid-column:span 7}.card--hero{background:var(--bg-hero);border:0;color:#fff;padding:48px 40px}.card--hero::after,.card--hero::before{content:"";position:absolute;border-radius:50%}.card--hero::before{top:-50%;right:-20%;width:400px;height:400px;background:rgba(255,255,255,.05)}.card--hero::after{bottom:-30%;left:-10%;width:300px;height:300px;background:rgba(255,255,255,.03)}.availability-badge{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);border:1px solid rgba(47,158,68,.4);border-radius:16px;font-size:.7rem;font-weight:600;color:#69db7c;z-index:2;white-space:nowrap}.availability-dot{width:8px;height:8px;background:#51cf66;border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}.hero-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:8px;position:relative;z-index:1}.hero-subtitle{font-size:1.15rem;color:rgba(255,255,255,.85);font-weight:500;margin-bottom:20px;position:relative;z-index:1;min-height:1.5em}.typing-cursor{animation:blink .8s infinite;font-weight:300}.download-btn,.hero-bio{position:relative;z-index:1}.hero-bio{color:rgba(255,255,255,.75);font-size:.92rem;line-height:1.75;max-width:560px}.download-btn{display:inline-flex;align-items:center;gap:8px;margin-top:20px;padding:10px 20px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);border-radius:24px;color:#fff;text-decoration:none;font-size:.85rem;font-weight:600;transition:all var(--transition);backdrop-filter:blur(4px)}.download-btn:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.2)}.download-btn svg,.info-item svg{width:18px;height:18px}.card--photo{display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-hero);border:0}.photo-wrapper{width:100%;aspect-ratio:1;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.2);position:relative}.photo-wrapper img{width:100%;height:100%;object-fit:cover;filter:grayscale(80%);transition:filter .5s ease,transform .5s ease}.photo-wrapper:hover img{filter:grayscale(0%);transform:scale(1.05)}.card-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:20px;display:flex;align-items:center;gap:8px}.card-heading::after{content:"";flex:1;height:1px;background:var(--border)}.info-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.info-item svg{color:var(--accent);flex-shrink:0;margin-top:2px}.info-item span{font-size:.88rem;color:var(--text-secondary)}.info-item a{color:var(--accent);text-decoration:none;font-weight:500}.info-item a:hover{text-decoration:underline}.social-links{display:flex;flex-direction:column;gap:8px;margin-top:20px}.social-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);text-decoration:none;color:var(--text-primary);border:1px solid var(--border);transition:all var(--transition)}.social-link:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);transform:translateX(4px)}.social-link svg{width:20px;height:20px}.social-link span{font-size:.88rem;font-weight:500}.skills-category{margin-bottom:24px}.skills-category:last-child{margin-bottom:0}.skills-label{font-size:.72rem;font-weight:700;color:var(--text-muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:7px 16px;background:var(--accent-soft);color:var(--accent);border-radius:24px;font-size:.78rem;font-weight:600;border:1px solid transparent;transition:all var(--transition)}.chip:hover{border-color:var(--accent);background:var(--accent-soft-2);transform:translateY(-1px)}.card--testimonial{grid-column:span 12}.testimonial{display:flex;flex-direction:column;align-items:center;text-align:center;padding:16px 20px}.testimonial-quote{font-size:1.1rem;font-style:italic;color:var(--text-secondary);line-height:1.8;max-width:700px;position:relative}.testimonial-quote::before{content:'"';position:absolute;top:-20px;left:-16px;font-size:4rem;color:var(--accent);opacity:.2;font-style:normal;line-height:1}.testimonial-author{margin-top:20px}.modal-header h3,.testimonial-name{font-size:.95rem;font-weight:700}.testimonial-role{font-size:.8rem;color:var(--text-muted);margin-top:2px}.card--projects{grid-column:span 12}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.project-card{border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;transition:all var(--transition);cursor:default}a.project-card{text-decoration:none;color:inherit;cursor:pointer}.project-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-hover)}.project-preview{height:140px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.project-preview img{width:100%;height:100%;object-fit:cover}.project-preview--placeholder{font-size:2.5rem}.project-preview--1{background:linear-gradient(135deg,#667eea,#764ba2)}.project-preview--2{background:linear-gradient(135deg,#f5af19,#f12711)}.project-preview--3{background:linear-gradient(135deg,#f093fb,#f5576c)}.project-preview--4{background:linear-gradient(135deg,#4facfe,#00f2fe)}.project-preview--5{background:linear-gradient(135deg,#43e97b,#38f9d7)}.project-info{padding:16px;background:var(--bg-card-alt)}.project-name{font-size:.95rem;font-weight:700;margin-bottom:4px}.project-role{font-size:.78rem;color:var(--accent);font-weight:600;margin-bottom:8px}.project-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.project-tag{font-size:.68rem;padding:3px 8px;background:var(--accent-soft);color:var(--accent);border-radius:10px;font-weight:600}.timeline{display:grid;gap:0}.timeline-item{display:grid;grid-template-columns:130px 1fr;gap:24px;padding:24px 0;border-bottom:1px solid var(--border);transition:background var(--transition)}.timeline-item:first-child{padding-top:0}.timeline-item:last-child{border-bottom:none;padding-bottom:0}.timeline-period{font-size:.78rem;color:var(--accent);font-weight:600;padding-top:4px}.timeline-company{font-size:1.1rem;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}.timeline-roles{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.timeline-role{font-size:.72rem;padding:4px 12px;background:var(--accent-soft);border-radius:16px;color:var(--accent);font-weight:600}.timeline-desc{font-size:.88rem;color:var(--text-secondary);line-height:1.7}.degree-institution{font-size:1.05rem;font-weight:700;margin-bottom:6px}.degree-career{font-size:.9rem;color:var(--text-secondary);margin-bottom:2px}.degree-specialty{font-size:.88rem;color:var(--text-muted);margin-top:6px;font-style:italic}.degree-period{font-size:.8rem;color:var(--accent);font-weight:600;margin-top:8px}.certs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;max-height:400px;overflow-y:auto;padding-right:8px}.certs-grid::-webkit-scrollbar{width:3px}.certs-grid::-webkit-scrollbar-track{background:0 0}.certs-grid::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px;opacity:.5}.cert-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:1px solid transparent}.cert-item:hover{background:var(--accent-soft);border-color:var(--accent);transform:translateX(4px)}.cert-year{font-size:.68rem;color:var(--accent);font-weight:700;min-width:36px}.cert-name{font-size:.82rem;font-weight:600}.cert-inst,.form-group label{font-size:.72rem;color:var(--text-muted)}.cert-inst{margin-top:2px}.references-content{display:none}.references-content.active{display:block}.ref-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);border-radius:24px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.ref-toggle:hover{background:var(--accent);color:#fff;box-shadow:0 4px 16px rgba(102,126,234,.3)}.ref-list{margin-top:20px;display:grid;gap:10px}.form-group input,.form-group textarea,.ref-item{padding:14px 16px;border-radius:var(--radius-sm);background:var(--bg-card-alt);border:1px solid var(--border);transition:all var(--transition)}.ref-item:hover{border-color:var(--accent)}.ref-name{font-weight:700;font-size:.88rem}.ref-role{font-size:.78rem;color:var(--text-muted);margin:2px 0}.ref-phone{font-size:.8rem;color:var(--accent);text-decoration:none;font-weight:500}.ref-phone:hover{text-decoration:underline}.contact-form{display:grid;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:700;text-transform:uppercase;letter-spacing:.08em}.form-group input,.form-group textarea{padding:12px 16px;color:var(--text-primary);font-family:var(--font);font-size:.88rem;outline:0}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-group textarea{resize:vertical;min-height:90px}.form-submit,.modal-body img{border-radius:var(--radius-sm)}.form-submit{padding:14px 28px;background:var(--bg-hero);color:#fff;border:0;font-size:.9rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.form-submit:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 4px 16px rgba(102,126,234,.3)}.form-error{color:#e03131;font-size:.78rem;font-weight:500}.form-status{text-align:center;padding:24px;font-size:.9rem;font-weight:500;display:flex;align-items:center;justify-content:center;min-height:200px}.form-status--success{color:#2f9e44}.form-status--error{color:#e03131}.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;align-items:center;justify-content:center;padding:20px}.modal-overlay.active{display:flex}.modal-content{background:var(--bg-card);border-radius:var(--radius);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.3);animation:modalIn .25s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid var(--border)}.modal-close{background:0 0;border:0;color:var(--text-muted);cursor:pointer;padding:8px;display:flex;border-radius:8px;transition:all var(--transition)}.modal-close:hover{color:var(--text-primary);background:var(--bg-card-alt)}.modal-body{padding:24px;display:flex;justify-content:center}.modal-body img{max-width:100%}@media (max-width:900px){.bento{grid-template-columns:repeat(6,1fr)}.card--certs,.card--contact,.card--education,.card--experience,.card--hero,.card--info,.card--photo,.card--references,.card--skills{grid-column:span 6}}@media (max-width:600px){.bento{grid-template-columns:1fr;padding:74px 12px 32px;gap:12px}.card{grid-column:span 1!important;padding:24px}.card--hero{padding:32px 24px}.hero-title{font-size:1.8rem}.timeline-item{grid-template-columns:1fr;gap:4px}.timeline-period{padding-top:0}.topbar{padding:10px 16px}}.scroll-top{position:fixed;bottom:30px;right:30px;width:48px;height:48px;border-radius:50%;background:var(--accent);border:0;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px rgba(102,126,234,.3);opacity:0;transform:translateY(20px);pointer-events:none;transition:all var(--transition);z-index:99}.scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-top:hover{transform:translateY(-3px);box-shadow:0 6px 24px rgba(102,126,234,.4)}.scroll-top svg{width:22px;height:22px}.g-recaptcha{margin-top:4px}.loader{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}