:root{--grad-start:#0f0c29;--grad-mid:#141432;--grad-end:#0d0d1a;--accent-1:#7c3aed;--accent-2:#06b6d4;--accent-3:#f472b6;--accent-grad:linear-gradient(135deg, var(--accent-1), var(--accent-2));--accent-grad-2:linear-gradient(135deg, var(--accent-2), var(--accent-3));--glass-bg:#ffffff0a;--glass-bg-md:#ffffff12;--glass-bg-strong:#ffffff1a;--glass-border:#ffffff1a;--glass-border-hover:#7c3aed80;--glass-shadow:0 8px 32px #0006;--glass-blur:blur(16px);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#7c3aed;--bg-page:var(--grad-start);--bg-card:var(--glass-bg);--bg-input:#ffffff0d;--border-default:var(--glass-border);--font-sans:"Sora", system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--ease:cubic-bezier(.4, 0, .2, 1);--transition:.3s var(--ease)}[data-theme=light]{--grad-start:#f8faff;--grad-mid:#eef2ff;--grad-end:#f0f4ff;--glass-bg:#ffffffa6;--glass-bg-md:#ffffffbf;--glass-bg-strong:#ffffffe0;--glass-border:#7c3aed26;--glass-border-hover:#7c3aed66;--glass-shadow:0 8px 32px #7c3aed1f;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-accent:#7c3aed;--bg-input:#7c3aed0d;--border-default:#7c3aed26}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}html,body{min-height:100%}body{font-family:var(--font-sans);background:linear-gradient(135deg, var(--grad-start) 0%, var(--grad-mid) 50%, var(--grad-end) 100%);color:var(--text-secondary);background-attachment:fixed;line-height:1.7;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 50% at 20% 20%,#7c3aed1f 0%,#0000 60%),radial-gradient(60% 40% at 80% 80%,#06b6d41a 0%,#0000 60%),radial-gradient(50% 60%,#f472b60f 0%,#0000 70%);position:fixed;inset:0}.portfolio-root{cursor:none;z-index:1;position:relative}.portfolio-root a,.portfolio-root button,.portfolio-root .btn,.portfolio-root [role=button]{cursor:none}@media (pointer:coarse){.portfolio-root,.portfolio-root a,.portfolio-root button,.portfolio-root .btn,.portfolio-root [role=button]{cursor:auto!important}.cursor-dot,.cursor-outline{display:none!important}}#bg-canvas{z-index:0;opacity:.4;width:100%;height:100%;position:fixed;inset:0}.cursor-dot{background:var(--accent-1);pointer-events:none;z-index:10000;width:8px;height:8px;transition:width .2s var(--ease), height .2s var(--ease), background .2s;border-radius:50%;position:fixed;transform:translate(-50%,-50%)}.cursor-outline{border:1.5px solid var(--accent-1);pointer-events:none;z-index:10000;opacity:.5;width:36px;height:36px;transition:width .35s var(--ease), height .35s var(--ease), opacity .3s;border-radius:50%;position:fixed;transform:translate(-50%,-50%)}.cursor-dot.cursor-hidden,.cursor-outline.cursor-hidden{opacity:0}.cursor-dot.grow{border:1.5px solid var(--accent-2);opacity:.3;background:0 0;width:48px;height:48px}.cursor-outline.grow{opacity:.15;border-color:var(--accent-2);width:60px;height:60px}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:linear-gradient(var(--accent-1), var(--accent-2));border-radius:99px}.navbar{transition:all var(--transition);z-index:1000;background:0 0;padding:1rem 0}.navbar-scrolled{-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);box-shadow:var(--glass-shadow);padding:.6rem 0;background:var(--glass-bg-strong)!important}.navbar-toggler{border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:6px 10px}.navbar-toggler:focus{box-shadow:none}.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28241, 245, 249, 0.9%29' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}[data-theme=light] .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2815, 23, 42, 0.9%29' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.navbar-brand{font-family:var(--font-mono);background:var(--accent-grad);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:600}.brand-bracket{-webkit-text-fill-color:var(--text-muted);color:var(--text-muted);background:0 0}.nav-link{font-family:var(--font-mono);transition:color var(--transition);border-radius:var(--radius-full);font-size:.82rem;color:var(--text-secondary)!important;padding:6px 12px!important}.nav-link:hover,.nav-link.active{background:var(--glass-bg-md);color:var(--text-primary)!important}.nav-number{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-right:3px;font-size:.75rem}@media (max-width:991px){.navbar-collapse{border-radius:var(--radius-md);border:1px solid #7c3aed4d;margin-top:12px;padding:10px 8px;box-shadow:0 16px 40px #0009;-webkit-backdrop-filter:none!important;background:#13102b!important}[data-theme=light] .navbar-collapse{border:1px solid #7c3aed2e;box-shadow:0 16px 40px #0000001a;background:#fff!important}.nav-link{border-radius:var(--radius-sm);align-items:center;margin:2px 0;font-size:.88rem;color:#f1f5f9!important;padding:11px 16px!important;display:flex!important}[data-theme=light] .nav-link{color:#0f172a!important}.nav-link:hover,.nav-link.active{color:#f1f5f9!important;background:#7c3aed26!important}[data-theme=light] .nav-link:hover,[data-theme=light] .nav-link.active{color:#0f172a!important;background:#7c3aed14!important}.nav-mobile-extras{border-top:1px solid #7c3aed26;flex-wrap:wrap;align-items:center;gap:10px;margin-top:6px;padding:10px 14px 4px;display:flex}.nav-extras-desktop{display:none!important}}.availability-badge{font-family:var(--font-mono);border-radius:var(--radius-full);border:1px solid var(--glass-border);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:6px;padding:5px 12px;font-size:.75rem;display:inline-flex}.avail-dot{background:#64748b;border-radius:50%;width:7px;height:7px;animation:2s infinite pulse-dot}.avail-available .avail-dot{background:#22c55e}.avail-busy .avail-dot{background:#f59e0b}.avail-open .avail-dot{background:#06b6d4}.avail-available{color:#22c55e;border-color:#22c55e4d}.avail-busy{color:#f59e0b;border-color:#f59e0b4d}.avail-open{color:#06b6d4;border-color:#06b6d44d}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.theme-toggle-btn{border:1px solid var(--glass-border);background:var(--glass-bg);width:38px;height:38px;color:var(--text-secondary);transition:all var(--transition);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:50%;justify-content:center;align-items:center;display:flex}.theme-toggle-btn:hover{background:var(--glass-bg-md);color:var(--text-primary);border-color:var(--glass-border-hover)}.section{z-index:2;padding:110px 0;position:relative}main.container,footer{z-index:2;position:relative}.section-heading-wrap{text-align:center;margin-bottom:4rem}.section-eyebrow{font-family:var(--font-mono);letter-spacing:3px;text-transform:uppercase;background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.75rem;font-size:.8rem;display:block}.section-title{color:var(--text-primary);margin-bottom:1rem;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;line-height:1.2}.section-subtitle{color:var(--text-muted);max-width:520px;margin:0 auto;font-size:1rem}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);transition:all var(--transition)}.glass-card:hover{background:var(--glass-bg-md);border-color:var(--glass-border-hover);box-shadow:var(--glass-shadow), 0 0 30px #7c3aed14;transform:translateY(-4px)}.hero{z-index:2;align-items:center;min-height:100vh;padding-top:80px;padding-bottom:40px;display:flex;position:relative}.hero-tag{font-family:var(--font-mono);color:var(--text-muted);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);animation:slideUp .6s var(--ease) forwards;opacity:0;align-items:center;gap:8px;margin-bottom:1.5rem;padding:6px 16px;font-size:.82rem;animation-delay:.1s;display:inline-flex}.hero-tag-dot{background:var(--accent-1);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-dot}.hero-name{color:var(--text-primary);letter-spacing:-2px;animation:slideUp .6s var(--ease) forwards;opacity:0;font-size:clamp(2.8rem,6vw,5rem);font-weight:800;line-height:1.1;animation-delay:.2s}.hero-name-gradient{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-typed-line{color:var(--text-secondary);min-height:80px;animation:slideUp .6s var(--ease) forwards;opacity:0;margin-top:.75rem;font-size:clamp(1.4rem,3vw,2.2rem);font-weight:600;animation-delay:.3s}#typed-text{background:var(--accent-grad-2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-desc{color:var(--text-secondary);max-width:560px;animation:slideUp .6s var(--ease) forwards;opacity:0;margin-top:1.25rem;font-size:1.05rem;line-height:1.8;animation-delay:.4s}.hero-actions{animation:slideUp .6s var(--ease) forwards;opacity:0;flex-wrap:wrap;gap:12px;margin-top:2rem;animation-delay:.5s;display:flex}.hero-scroll-hint{animation:slideUp .6s var(--ease) forwards;opacity:0;font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:10px;margin-top:3rem;font-size:.75rem;animation-delay:.7s;display:flex}.scroll-line{background:linear-gradient(90deg, var(--accent-1), transparent);width:60px;height:1px}.hero-card{background:var(--glass-bg-md);border:1px solid var(--glass-border);border-radius:var(--radius-xl);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);animation:slideUp .6s var(--ease) forwards;opacity:0;padding:2rem;animation-delay:.6s}.hero-code-block{font-family:var(--font-mono);color:var(--text-secondary);font-size:.82rem;line-height:1.9}.code-keyword{color:#c678dd}.code-string{color:#98c379}.code-property{color:#e06c75}.code-value{color:#56b6c2}.code-comment{color:var(--text-muted);font-style:italic}.code-bracket{color:var(--text-muted)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.hero-float{animation:5s ease-in-out infinite float}@keyframes slideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.btn-grad{background:var(--accent-grad);border-radius:var(--radius-full);transition:all var(--transition);border:none;align-items:center;gap:8px;padding:12px 28px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex;color:#fff!important}.btn-grad:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed66}.btn-glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);transition:all var(--transition);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);align-items:center;gap:8px;padding:12px 28px;font-size:.9rem;font-weight:500;text-decoration:none;display:inline-flex;color:var(--text-primary)!important}.btn-glass:hover{background:var(--glass-bg-md);border-color:var(--glass-border-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0003}.btn-outline-primary{border-radius:var(--radius-full);transition:all var(--transition);background:0 0;align-items:center;gap:8px;padding:10px 24px;font-size:.9rem;font-weight:500;display:inline-flex;color:var(--accent-1)!important;border-color:var(--accent-1)!important}.btn-outline-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #7c3aed40;border-color:var(--accent-1)!important;color:var(--accent-1)!important;background:#7c3aed1f!important}.about-text{color:var(--text-secondary);margin-bottom:1.25rem;font-size:1rem;line-height:1.85}.about-text:last-of-type{margin-bottom:0}.stats-row{flex-wrap:wrap;gap:1rem;margin-top:2rem;display:flex}.stat-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);text-align:center;min-width:100px;transition:all var(--transition);flex:1;padding:1rem 1.5rem}.stat-card:hover{border-color:var(--glass-border-hover);background:var(--glass-bg-md)}.stat-number{font-family:var(--font-mono);background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700;line-height:1.2;display:block}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px;font-size:.72rem;display:block}.profile-img-wrapper{display:inline-block;position:relative}.profile-ring{background:var(--accent-grad);z-index:-1;opacity:.6;border-radius:50%;animation:8s linear infinite spin-ring;position:absolute;inset:-8px}.profile-ring-inner{background:var(--bg-page,#0f0c29);z-index:-1;border-radius:50%;position:absolute;inset:-4px}@keyframes spin-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-photo{object-fit:cover;border:3px solid var(--glass-border);border-radius:50%;width:260px;height:260px;display:block}.profile-badge{background:var(--glass-bg-strong);border:1px solid var(--glass-border-hover);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);color:var(--text-primary);font-family:var(--font-mono);border-radius:var(--radius-full);white-space:nowrap;padding:6px 14px;font-size:.75rem;position:absolute;bottom:10px;right:-10px}.skill-category-header{align-items:center;gap:10px;margin-bottom:1rem;display:flex}.skill-category-label{font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-size:.78rem}.skill-category-line{background:linear-gradient(90deg, var(--glass-border), transparent);flex:1;height:1px}.skill-badge{color:var(--text-secondary);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-full);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:all var(--transition);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;padding:7px 16px;font-size:.85rem;font-weight:500;display:inline-flex}.skill-badge:hover{border-color:var(--accent-1);color:var(--text-primary);background:#7c3aed1f;transform:translateY(-2px);box-shadow:0 4px 16px #7c3aed33}.skill-badge i{color:var(--accent-2);font-size:.9rem}.timeline{padding-left:2rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent-1), var(--accent-2), transparent);opacity:.4;width:1px;position:absolute;top:0;bottom:0;left:7px}.timeline-item{margin-bottom:2.5rem;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-dot{background:var(--accent-grad);border:3px solid var(--bg-page,#0f0c29);z-index:1;border-radius:50%;width:16px;height:16px;position:absolute;top:6px;left:-2rem;box-shadow:0 0 12px #7c3aed80}[data-theme=light] .timeline-dot{border-color:var(--grad-start)}.timeline-content{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:all var(--transition);padding:1.5rem}.timeline-content:hover{background:var(--glass-bg-md);border-color:var(--glass-border-hover)}.timeline-title{color:var(--text-primary);margin-bottom:4px;font-size:1.05rem;font-weight:700}.timeline-org{color:var(--text-muted);margin-bottom:0;font-size:.9rem}.timeline-org i{color:var(--accent-2)}.timeline-badge{font-family:var(--font-mono);color:var(--accent-2);border-radius:var(--radius-full);white-space:nowrap;background:#06b6d414;border:1px solid #06b6d433;padding:3px 10px;font-size:.75rem}.current-badge{font-family:var(--font-mono);color:#22c55e;border-radius:var(--radius-full);background:#22c55e14;border:1px solid #22c55e40;margin-left:8px;padding:2px 10px;font-size:.68rem}.timeline-bullets{margin:.75rem 0 0;padding:0;list-style:none}.timeline-bullets li{color:var(--text-secondary);padding:3px 0 3px 1.1rem;font-size:.9rem;line-height:1.6;position:relative}.timeline-bullets li:before{content:"▸";background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:.75rem;position:absolute;top:5px;left:0}.featured-label{font-family:var(--font-mono);background:var(--accent-grad);-webkit-text-fill-color:transparent;letter-spacing:1px;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:.78rem}.project-title{color:var(--text-primary);margin-bottom:.75rem;font-size:1.4rem;font-weight:700;line-height:1.3}.project-desc{color:var(--text-secondary);background:var(--glass-bg-md);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:1.25rem;font-size:.95rem;line-height:1.75}.tech-tags{flex-wrap:wrap;gap:6px;display:flex}.tech-tag{font-family:var(--font-mono);color:var(--accent-2);border-radius:var(--radius-full);background:#06b6d414;border:1px solid #06b6d433;padding:3px 10px;font-size:.72rem}.project-img-wrap{border-radius:var(--radius-md);border:1px solid var(--glass-border);position:relative;overflow:hidden}.project-img-wrap img{width:100%;transition:transform .5s var(--ease);display:block}.project-img-wrap:hover img{transform:scale(1.03)}.project-img-overlay{color:#fff;opacity:0;transition:opacity var(--transition);background:#7c3aedb3;justify-content:center;align-items:center;gap:8px;font-size:.95rem;font-weight:600;display:flex;position:absolute;inset:0}.project-img-wrap:hover .project-img-overlay{opacity:1}.project-placeholder{background:var(--glass-bg);height:200px;color:var(--text-muted);border-radius:var(--radius-md);border:1px solid var(--glass-border);justify-content:center;align-items:center;font-size:3rem;display:flex}.project-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:all var(--transition);height:100%}.project-card:hover{background:var(--glass-bg-md);border-color:var(--glass-border-hover);box-shadow:var(--glass-shadow);transform:translateY(-6px)}.project-folder-icon{background:var(--accent-grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem}.card-link{color:var(--text-muted);transition:color var(--transition);font-size:1.1rem;text-decoration:none}.card-link:hover{color:var(--text-primary)}.project-links{flex-wrap:wrap;gap:12px;display:flex}.project-link-btn{color:var(--text-muted);transition:color var(--transition);align-items:center;gap:6px;padding:4px 0;font-size:.85rem;text-decoration:none;display:inline-flex}.project-link-btn:hover{color:var(--text-primary)}.cert-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:all var(--transition);color:var(--text-secondary);align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;text-decoration:none;display:flex}.cert-card:hover{background:var(--glass-bg-md);border-color:var(--glass-border-hover);color:var(--text-primary);transform:translate(6px);box-shadow:0 4px 20px #7c3aed26}.cert-icon{border-radius:var(--radius-sm);width:44px;height:44px;color:var(--accent-1);background:#7c3aed1f;border:1px solid #7c3aed33;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.cert-title{color:var(--text-primary);margin-bottom:2px;font-size:.95rem;font-weight:600}.cert-org{color:var(--text-muted);margin:0;font-size:.82rem}.cert-arrow{color:var(--text-muted);transition:transform var(--transition);margin-left:auto;font-size:.85rem}.cert-card:hover .cert-arrow{color:var(--accent-1);transform:translate(4px)}.custom-input{transition:all var(--transition);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);font-size:.95rem;background:var(--bg-input)!important;border:1px solid var(--glass-border)!important;border-radius:var(--radius-md)!important;color:var(--text-primary)!important;padding:12px 16px!important}.custom-input::placeholder{color:var(--text-muted)!important}.custom-input:focus{outline:none;background:var(--glass-bg-md)!important;border-color:var(--accent-1)!important;color:var(--text-primary)!important;box-shadow:0 0 0 3px #7c3aed26!important}.contact-status{min-height:1.5rem;color:var(--text-muted);font-size:.9rem;font-weight:500}.contact-status.success{color:#22c55e}.contact-status.error{color:#f87171}.result-box{background:var(--glass-bg-md);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);color:var(--text-secondary);white-space:pre-wrap;padding:1.5rem;font-size:.95rem;line-height:1.75}.message-form-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:1.75rem}.emoji-picker{flex-wrap:wrap;gap:8px;display:flex}.emoji-btn{border:1px solid var(--glass-border);background:var(--glass-bg);width:38px;height:38px;transition:all var(--transition);cursor:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.emoji-btn:hover,.emoji-btn.selected{border-color:var(--accent-1);background:#7c3aed26;transform:scale(1.1)}@media (pointer:coarse){.emoji-btn{cursor:pointer}}.visitor-message-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:all var(--transition);gap:1rem;margin-bottom:.75rem;padding:1rem 1.25rem;display:flex}.visitor-message-card:hover{background:var(--glass-bg-md);border-color:var(--glass-border-hover)}.vm-emoji{flex-shrink:0;font-size:1.5rem}.vm-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px;display:flex}.vm-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.vm-date{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}.vm-text{color:var(--text-secondary);margin:0;font-size:.88rem;line-height:1.6}#chat-icon{background:var(--accent-grad);color:#fff;z-index:999;width:56px;height:56px;transition:all var(--transition);cursor:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 20px #7c3aed80}#chat-icon:hover{transform:scale(1.1);box-shadow:0 6px 28px #7c3aed99}@media (pointer:coarse){#chat-icon{cursor:pointer}}.chat-tooltip{white-space:nowrap;background:var(--glass-bg-strong);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);color:var(--text-primary);border-radius:var(--radius-full);opacity:0;transition:opacity var(--transition);pointer-events:none;padding:5px 12px;font-size:.8rem;position:absolute;bottom:50%;right:66px;transform:translateY(50%)}#chat-icon:hover .chat-tooltip{opacity:1}#chat-window{background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:var(--radius-xl);width:360px;height:500px;-webkit-backdrop-filter:var(--glass-blur);z-index:998;opacity:0;pointer-events:none;transition:all var(--transition);box-shadow:var(--glass-shadow);flex-direction:column;display:flex;position:fixed;bottom:96px;right:28px;overflow:hidden;transform:scale(.9)translateY(20px)}#chat-window.open{opacity:1;pointer-events:all;transform:scale(1)translateY(0)}@media (max-width:480px){#chat-window{width:calc(100vw - 24px);bottom:88px;right:12px}}#chat-header{border-bottom:1px solid var(--glass-border);background:#7c3aed14;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.chat-header-info{align-items:center;gap:10px;display:flex}.chat-avatar{background:var(--accent-grad);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;display:flex}.chat-header-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.chat-header-status{color:#22c55e;align-items:center;gap:5px;font-size:.72rem;display:flex}.status-dot{background:#22c55e;border-radius:50%;width:6px;height:6px;display:inline-block}.chat-close{color:var(--text-muted);transition:color var(--transition);cursor:none;background:0 0;border:none;font-size:1rem}@media (pointer:coarse){.chat-close{cursor:pointer}}.chat-close:hover{color:var(--text-primary)}#chat-body{scrollbar-width:thin;scrollbar-color:var(--glass-border) transparent;flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.chat-message{border-radius:var(--radius-md);max-width:82%;color:var(--text-primary);padding:10px 14px;font-size:.88rem;line-height:1.55}.bot-message{background:var(--glass-bg-md);border:1px solid var(--glass-border);border-bottom-left-radius:4px;align-self:flex-start}.user-message{background:var(--accent-grad);border-bottom-right-radius:4px;align-self:flex-end;color:#fff!important}.loading-indicator{background:var(--glass-bg-md);border:1px solid var(--glass-border);border-radius:var(--radius-md);border-bottom-left-radius:4px;align-self:flex-start;gap:5px;padding:12px 16px;display:flex}.loading-indicator span{background:var(--accent-1);border-radius:50%;width:7px;height:7px;animation:1.2s infinite bounce}.loading-indicator span:nth-child(2){animation-delay:.2s}.loading-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}#chat-input{border-top:1px solid var(--glass-border);align-items:center;gap:8px;padding:12px 14px;display:flex}#user-input{flex:1;font-size:.85rem;background:var(--bg-input)!important;border:1px solid var(--glass-border)!important;border-radius:var(--radius-full)!important;color:var(--text-primary)!important;padding:8px 14px!important}#user-input::placeholder{color:var(--text-muted)!important}#user-input:focus{outline:none;border-color:var(--accent-1)!important;box-shadow:none!important;background:var(--glass-bg-md)!important}.voice-btn,.chat-send-btn{border:1px solid var(--glass-border);background:var(--glass-bg);width:34px;height:34px;color:var(--text-muted);transition:all var(--transition);cursor:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;display:flex}@media (pointer:coarse){.voice-btn,.chat-send-btn{cursor:pointer}}.chat-send-btn{background:var(--accent-grad);color:#fff;border:none}.voice-btn:hover{background:var(--glass-bg-md);color:var(--text-primary)}.chat-send-btn:hover{opacity:.85;transform:scale(1.05)}.voice-btn.listening{color:var(--accent-1);background:#7c3aed33;animation:1s infinite pulse-voice}@keyframes pulse-voice{0%,to{box-shadow:0 0 #7c3aed66}50%{box-shadow:0 0 0 8px #7c3aed00}}.skill-modal .modal-content{background:var(--glass-bg-strong);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-lg);color:var(--text-primary)}.skill-modal .modal-header{border-bottom:1px solid var(--glass-border);padding:1.25rem 1.5rem}.skill-modal .modal-title{color:var(--text-primary);font-weight:700}.skill-modal .modal-body{color:var(--text-secondary);padding:1.5rem;font-size:.95rem;line-height:1.75}.skill-modal .modal-footer{border-top:1px solid var(--glass-border);padding:1rem 1.5rem}.skill-modal .btn-close{filter:invert()brightness(.6)}[data-theme=light] .skill-modal .btn-close{filter:none}.footer{z-index:2;text-align:center;border-top:1px solid var(--glass-border);margin-top:2rem;padding:3rem 0;position:relative}.social-links{justify-content:center;gap:1.25rem;margin-bottom:1.5rem;display:flex}.social-link{border:1px solid var(--glass-border);background:var(--glass-bg);width:42px;height:42px;color:var(--text-muted);transition:all var(--transition);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;text-decoration:none;display:flex}.social-link:hover{border-color:var(--accent-1);color:var(--text-primary);background:#7c3aed1f;transform:translateY(-3px)}.footer-credit{color:var(--text-muted);margin-bottom:4px;font-size:.88rem}.footer-credit span{color:var(--accent-1);font-weight:600}.footer-copy{color:var(--text-muted);font-size:.8rem;font-family:var(--font-mono)}[data-aos=fade-up]{opacity:0;transition:transform .7s var(--ease), opacity .7s var(--ease);transform:translateY(30px)}[data-aos=fade-up].aos-animate{opacity:1;transform:translateY(0)}[data-aos=fade-right]{opacity:0;transition:transform .7s var(--ease), opacity .7s var(--ease);transform:translate(-30px)}[data-aos=fade-right].aos-animate{opacity:1;transform:translate(0)}[data-aos=fade-left]{opacity:0;transition:transform .7s var(--ease), opacity .7s var(--ease);transform:translate(30px)}[data-aos=fade-left].aos-animate{opacity:1;transform:translate(0)}@media (max-width:768px){.section{padding:70px 0}.hero-name{letter-spacing:-1px}.hero-card{margin-top:2rem}.profile-photo{width:200px;height:200px}#chat-window{bottom:84px}}@media (max-width:480px){.section{padding:50px 0}.hero{padding-top:100px}.stats-row{gap:.5rem}.stat-card{padding:.75rem 1rem}}.weather-overlay{pointer-events:none;z-index:0;transition:opacity 1.5s;position:fixed;inset:0;overflow:hidden}.weather-overlay.hidden{opacity:0}.weather-widget{font-family:var(--font-mono);color:var(--text-muted);background:var(--glass-bg-strong);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-full);z-index:500;pointer-events:none;align-items:center;gap:8px;padding:5px 12px;font-size:.72rem;transition:all .5s;display:flex;position:fixed;top:72px;right:20px}.weather-widget-icon{font-size:.9rem}@media (max-width:768px){.weather-widget{display:none}}.rain-drop{background:linear-gradient(#0000,#93c5fd99);border-radius:1px;width:1.5px;animation:linear infinite rain-fall;position:absolute;top:-100px}@keyframes rain-fall{to{transform:translateY(110vh)translate(30px)}}.snow-flake{background:#ffffffd9;border-radius:50%;animation:linear infinite snow-fall;position:absolute;top:-20px}@keyframes snow-fall{0%{opacity:.9;transform:translateY(0)translate(0)rotate(0)}50%{transform:translateY(50vh)translate(30px)rotate(180deg)}to{opacity:0;transform:translateY(110vh)translate(-20px)rotate(360deg)}}.lightning-flash{pointer-events:none;background:#ffffff1f;animation:6s ease-in-out infinite lightning;position:absolute;inset:0}@keyframes lightning{0%,94%,98%,to{opacity:0}95%,97%{opacity:1}}.fog-layer{background:linear-gradient(90deg,#0000,#cbd5e114,#0000);border-radius:50%;width:200%;height:120px;animation:linear infinite fog-drift;position:absolute}@keyframes fog-drift{0%{transform:translate(-50%)}to{transform:translate(0%)}}.sun-glow{pointer-events:none;background:radial-gradient(circle,#fbbf241f 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:5s ease-in-out infinite sun-pulse;position:absolute;top:-200px;right:5%}@keyframes sun-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.cloud-shape{filter:blur(8px);background:#94a3b812;border-radius:50px;animation:linear infinite cloud-drift;position:absolute}@keyframes cloud-drift{0%{transform:translate(-120%)}to{transform:translate(120vw)}}html[data-weather=rain] body:before{background:radial-gradient(80% 50% at 20% 20%,#1e40af2e 0%,#0000 60%),radial-gradient(60% 40% at 80% 80%,#06b6d41a 0%,#0000 60%)}html[data-weather=storm] body:before{background:radial-gradient(80% 50% at 50% 0,#1e1b4b4d 0%,#0000 60%)}html[data-weather=snow] body:before{background:radial-gradient(80% 50% at 50% 0,#bae6fd1f 0%,#0000 60%)}html[data-weather=fog] body:before{background:radial-gradient(100% 60%,#94a3b826 0%,#0000 70%)}html[data-weather=sunny] body:before{background:radial-gradient(60% 40% at 80% 10%,#fbbf2424 0%,#0000 60%),radial-gradient(80% 50% at 20% 80%,#7c3aed1a 0%,#0000 60%)}html[data-weather=cloudy] body:before{background:radial-gradient(100% 50% at 50% 0,#64748b1f 0%,#0000 60%)}html[data-weather=partly-cloudy] body:before{background:radial-gradient(80% 50% at 70% 0,#64748b14 0%,#0000 60%)}.blog-page-root{background:linear-gradient(135deg, var(--grad-start) 0%, var(--grad-mid) 50%, var(--grad-end) 100%);min-height:100vh;color:var(--text-secondary);background-attachment:fixed;cursor:auto!important}.blog-page-root *{cursor:auto!important}
