@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Mono:wght@400;500&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,300&display=swap";:root{--bg: #0A0A0A;--bg-raised: #111111;--bg-card: #1A1A1A;--bg-card-hover:#222222;--border: rgba(167, 139, 250, .12);--border-hover: rgba(167, 139, 250, .28);--text: #e0e0e0;--text-muted: #999;--text-faint: #444;--accent: #A78BFA;--accent-dark: #8B5CF6;--accent-dim: rgba(167, 139, 250, .12);--accent-glow: 0 0 12px rgba(167, 139, 250, .8);--red: #ff4e4e;--blue: #5b8fff;--skill-bg: #222222;--font-display: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", "Fira Code", monospace;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 4rem;--space-xl: 8rem;--container: 1100px;--header-h: 72px;--radius: 4px;--radius-lg: 12px;--ease: cubic-bezier(.16, 1, .3, 1);--fast: .15s var(--ease);--mid: .35s var(--ease);--slow: .6s var(--ease)}body.light-mode{--bg: #ffffff;--bg-raised: #f8f8f8;--bg-card: #F8F8F8;--bg-card-hover:#efefef;--border: rgba(0,0,0,.08);--border-hover: rgba(0,0,0,.18);--text: #162447;--text-muted: #4a5e80;--text-faint: #c0c8d8;--accent: #AA8E43;--accent-dark: #8C7438;--accent-dim: rgba(170, 142, 67, .12);--accent-glow: 0 0 8px rgba(22, 36, 71, .4);--red: #d32f2f;--blue: #162447;--skill-bg: #e0e0e0}html.preload-light body{background-color:#fff!important;color:#162447!important}html.preload-dark body{background-color:#0a0a0a!important;color:#e0e0e0!important}body.no-transition,body.no-transition *{transition:none!important}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--header-h);scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg-raised)}body{background-color:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;font-weight:300;line-height:1.75;cursor:none;overflow-x:hidden;transition:background-color .4s ease,color .4s ease;padding-top:var(--header-h)}a{color:inherit;text-decoration:none;cursor:none}button{cursor:none}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}.grain-overlay{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}body.light-mode .grain-overlay{opacity:.04}.cursor-dot{position:fixed;width:6px;height:6px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:opacity .2s ease,transform .1s ease}.cursor-ring{position:fixed;width:32px;height:32px;border:1px solid var(--accent);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),border-color .25s ease,opacity .2s ease;opacity:.5}.cursor-ring.hovering{width:52px;height:52px;opacity:.8;border-color:var(--accent)}.skip-link{position:absolute;top:-100px;left:1rem;background:var(--accent);color:var(--bg);padding:.5rem 1rem;border-radius:var(--radius);font-family:var(--font-mono);font-size:.8rem;z-index:10001;transition:top .2s ease}.skip-link:focus{top:1rem}.container{max-width:var(--container);margin:0 auto;padding:0 var(--space-md)}section{padding:var(--space-xl) 0}@media (max-width: 768px){section{padding:var(--space-lg) 0}.container{padding:0 var(--space-sm)}}.display-title{font-family:var(--font-display);font-size:clamp(3rem,8vw,7rem);line-height:1.05;letter-spacing:-.02em;color:var(--text)}.display-title em{font-style:italic;color:var(--accent)}.section-label{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:.75rem;margin-bottom:var(--space-md)}.section-label:before{content:"";display:block;width:2rem;height:1px;background:var(--accent)}.section-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);line-height:1.1;letter-spacing:-.02em;color:var(--text);margin-bottom:var(--space-md)}.body-text{font-family:var(--font-body);font-size:1rem;font-weight:300;line-height:1.8;color:var(--text-muted);max-width:60ch}.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--border);z-index:1000;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}.site-header.scrolled{background:#0a0a0aeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border)}body.light-mode .site-header.scrolled{background:#fffffff2}.header-inner{max-width:var(--container);margin:0 auto;padding:0 var(--space-md);height:100%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-md)}.header-logo{font-family:var(--font-mono);font-size:.85rem;font-weight:500;color:var(--text);letter-spacing:.02em;transition:color var(--fast);white-space:nowrap}.header-logo span,.header-logo:hover{color:var(--accent)}.header-nav{display:flex;align-items:center;justify-content:center;gap:.25rem}.nav-link{font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:.05em;color:var(--text-muted);padding:.5rem .75rem;border-radius:var(--radius);transition:color var(--fast),background var(--fast);position:relative}.nav-link:hover,.nav-link.active{color:var(--text);background:var(--accent-dim)}.nav-link.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:3px;height:3px;background:var(--accent);border-radius:50%}.header-controls{display:flex;align-items:center;gap:var(--space-xs)}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-muted);font-size:.85rem;transition:all var(--fast);position:relative}.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.resume-dropdown{position:relative}.resume-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.5rem;min-width:180px;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity var(--fast),transform var(--fast);z-index:100}.resume-dropdown.open .resume-menu{opacity:1;pointer-events:all;transform:translateY(0)}.resume-menu a{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;border-radius:var(--radius);font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);transition:all var(--fast)}.resume-menu a:hover{background:var(--accent-dim);color:var(--accent)}.lang-btn{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.05em}#progress-bar{position:fixed;top:var(--header-h);left:0;height:2px;background:var(--accent);width:0%;z-index:1001;transition:width .1s linear;box-shadow:0 0 8px var(--accent)}.hamburger{display:none;flex-direction:column;gap:4px;padding:8px;background:none;border:none}.hamburger span{display:block;width:20px;height:1.5px;background:var(--text);transition:all var(--mid);transform-origin:center}.hamburger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}.mobile-nav{display:none;position:fixed;inset:var(--header-h) 0 0 0;background:var(--bg);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity var(--mid)}.mobile-nav.open{opacity:1;pointer-events:all}.mobile-nav .nav-link{font-size:1.5rem;letter-spacing:.02em;color:var(--text-muted)}.mobile-nav .nav-link:hover{color:var(--accent);background:none}@media (max-width: 768px){.header-nav{display:none}.hamburger,.mobile-nav{display:flex}}#hero{min-height:calc(100vh - var(--header-h));display:flex;align-items:center;padding:var(--space-xl) 0;position:relative;overflow:hidden}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);align-items:center}.hero-content{position:relative;z-index:1}.hero-mono-label{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:.5rem}.hero-mono-label:before{content:">";color:var(--text-faint)}.hero-title{font-family:var(--font-display);font-size:clamp(3.2rem,7vw,6rem);line-height:1.05;letter-spacing:-.03em;margin-bottom:var(--space-md)}.hero-title em{font-style:italic;color:var(--accent)}.hero-subtitle{font-size:1.05rem;font-weight:300;line-height:1.8;color:var(--text-muted);max-width:48ch;margin-bottom:var(--space-md)}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.75rem;background:var(--accent);color:var(--bg);font-family:var(--font-mono);font-size:.82rem;font-weight:500;letter-spacing:.05em;border-radius:var(--radius);border:1px solid var(--accent);transition:all var(--mid)}.btn-primary:hover{background:transparent;color:var(--accent);box-shadow:var(--accent-glow)}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.75rem;background:transparent;color:var(--text-muted);font-family:var(--font-mono);font-size:.82rem;font-weight:500;letter-spacing:.05em;border-radius:var(--radius);border:1px solid var(--border);transition:all var(--mid)}.btn-secondary:hover{border-color:var(--text-muted);color:var(--text)}.hero-visual{position:relative}.hero-terminal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;font-family:var(--font-mono);font-size:.82rem;line-height:1.7}.terminal-bar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-raised);border-bottom:1px solid var(--border)}.terminal-dot{width:10px;height:10px;border-radius:50%}.terminal-dot.red{background:#ff5f57}.terminal-dot.yellow{background:#febc2e}.terminal-dot.green{background:#28c840}.terminal-file{margin-left:auto;color:var(--text-faint);font-size:.72rem}.terminal-body{padding:1.5rem;color:var(--text-muted)}.terminal-line{display:flex;gap:1rem}.terminal-num{color:var(--text-faint);user-select:none;min-width:1.5rem;text-align:right}.terminal-code{color:var(--text)}.t-keyword{color:#c792ea}.t-func{color:#82aaff}.t-string{color:#c3e88d}.t-prop{color:var(--accent)}.t-comment{color:var(--text-faint);font-style:italic}.t-number{color:#f78c6c}.t-type{color:#ffcb6b}.t-cursor{display:inline-block;width:2px;height:1em;background:var(--accent);vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);margin-top:1rem;overflow:hidden}.hero-stat{background:var(--bg-card);padding:1rem;text-align:center}.hero-stat-num{font-family:var(--font-display);font-size:1.8rem;color:var(--accent);line-height:1;display:block}.hero-stat-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;margin-top:.25rem;display:block}@media (max-width: 900px){.hero-grid{grid-template-columns:1fr;gap:var(--space-lg)}.hero-visual{order:-1}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:var(--space-md)}.skill-category{background:var(--bg-card);padding:1.75rem;transition:background var(--fast)}.skill-category:hover{background:var(--bg-card-hover)}.skill-category-title{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem}.skill-items{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);transition:all var(--fast)}.skill-tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.skill-tag i{font-size:.9rem}.projects-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-md);gap:var(--space-sm);flex-wrap:wrap}.project-controls{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:var(--space-md)}.search-input{flex:1;min-width:220px;padding:.7rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:.82rem;outline:none;transition:border-color var(--fast)}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-faint)}.sort-select{padding:.7rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-family:var(--font-mono);font-size:.82rem;outline:none;transition:border-color var(--fast);cursor:none}.sort-select:focus{border-color:var(--accent)}.filter-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:var(--space-md)}.filter-tag{padding:.35rem .85rem;background:transparent;border:1px solid var(--border);border-radius:99px;color:var(--text-muted);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;cursor:none;transition:all var(--fast)}.filter-tag:hover,.filter-tag.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.project-card{background:var(--bg-card);padding:1.75rem;display:flex;flex-direction:column;gap:1rem;transition:background var(--fast);position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity var(--mid)}.project-card:hover{background:var(--bg-card-hover)}.project-card:hover:before{opacity:1}.project-image-wrap{aspect-ratio:16/9;overflow:hidden;border-radius:var(--radius);background:var(--bg-raised);border:1px solid var(--border)}.project-image-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}.project-card:hover .project-image-wrap img{transform:scale(1.04)}.project-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.project-date{font-family:var(--font-mono);font-size:.68rem;color:var(--text-faint);letter-spacing:.06em}.project-featured-badge{font-family:var(--font-mono);font-size:.62rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .5rem;background:var(--accent-dim);color:var(--accent);border-radius:var(--radius);border:1px solid rgba(167,139,250,.2)}.project-title{font-family:var(--font-display);font-size:1.4rem;line-height:1.2;color:var(--text)}.project-desc{font-size:.9rem;font-weight:300;line-height:1.7;color:var(--text-muted);flex:1}.tech-bars{display:flex;flex-direction:column;gap:.4rem}.tech-bar-item{display:flex;align-items:center;gap:.75rem}.tech-bar-name{font-family:var(--font-mono);font-size:.7rem;color:var(--text-faint);min-width:80px;letter-spacing:.04em}.tech-bar-track{flex:1;height:3px;background:var(--bg-raised);border-radius:99px;overflow:hidden}.tech-bar-fill{height:100%;background:var(--accent);border-radius:99px;width:0;transition:width 1s var(--ease)}.tech-bar-pct{font-family:var(--font-mono);font-size:.65rem;color:var(--text-faint);min-width:2.5rem;text-align:right}.project-links{display:flex;gap:.5rem;margin-top:auto}.project-link{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.04em;border-radius:var(--radius);border:1px solid var(--border);color:var(--text-muted);transition:all var(--fast)}.project-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.project-link.primary{background:var(--accent);border-color:var(--accent);color:var(--bg)}.project-link.primary:hover{background:transparent;color:var(--accent)}.no-results{grid-column:1/-1;padding:var(--space-xl);text-align:center;font-family:var(--font-mono);font-size:.85rem;color:var(--text-faint)}.about-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:var(--space-xl);align-items:start}.about-sidebar{position:sticky;top:calc(var(--header-h) + 2rem)}.about-name-block{margin-bottom:var(--space-md)}.about-name{font-family:var(--font-display);font-size:2.5rem;line-height:1.1;margin-bottom:.5rem}.about-role{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);letter-spacing:.1em;text-transform:uppercase}.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:var(--space-md)}.about-stat{background:var(--bg-card);padding:1.25rem}.about-stat-num{font-family:var(--font-display);font-size:2.5rem;color:var(--accent);line-height:1;display:block}.about-stat-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase;margin-top:.35rem;display:block}.about-socials{display:flex;gap:.5rem}.social-link{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.9rem;transition:all var(--fast)}.social-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.about-body p{font-size:1rem;font-weight:300;line-height:1.85;color:var(--text-muted);margin-bottom:1.5rem}.certs-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:var(--space-md)}.cert-item{background:var(--bg-card);padding:1rem 1.25rem;transition:background var(--fast)}.cert-item:hover{background:var(--bg-card-hover)}.cert-title{font-size:.85rem;font-weight:400;color:var(--text);margin-bottom:.2rem}.cert-issuer{font-family:var(--font-mono);font-size:.68rem;color:var(--text-faint);letter-spacing:.04em}@media (max-width: 900px){.about-grid{grid-template-columns:1fr}.about-sidebar{position:static}.certs-grid{grid-template-columns:1fr}}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);align-items:start}.contact-info h3{font-family:var(--font-display);font-size:2rem;color:var(--text);margin-bottom:var(--space-sm)}.contact-info p{font-weight:300;color:var(--text-muted);margin-bottom:var(--space-md)}.contact-links{display:flex;flex-direction:column;gap:.75rem}.contact-link{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;color:var(--text-muted);transition:all var(--fast)}.contact-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.contact-link i{color:var(--accent);width:20px;text-align:center}.contact-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}.form-input,.form-textarea{padding:.85rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:.9rem;font-weight:300;outline:none;transition:border-color var(--fast),box-shadow var(--fast);resize:vertical}.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-textarea{min-height:130px}.form-error{font-family:var(--font-mono);font-size:.72rem;color:var(--red);margin-top:.25rem;display:none}.form-error.visible{display:block}.form-submit{align-self:flex-start}#form-status{font-family:var(--font-mono);font-size:.82rem;padding:.75rem 1rem;border-radius:var(--radius);display:none}#form-status.success{display:block;background:#28c8401a;color:#28c840;border:1px solid rgba(40,200,64,.2)}#form-status.error{display:block;background:#ff4e4e1a;color:var(--red);border:1px solid rgba(255,78,78,.2)}@media (max-width: 768px){.contact-grid{grid-template-columns:1fr}}.cta-section{text-align:center;border-top:1px solid var(--border)}.cta-section h2{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);color:var(--text);margin-bottom:var(--space-sm)}.cta-section p{font-weight:300;color:var(--text-muted);max-width:50ch;margin:0 auto var(--space-md)}.site-footer{border-top:1px solid var(--border);padding:var(--space-md) 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm)}.footer-copy{font-family:var(--font-mono);font-size:.72rem;color:var(--text-faint);letter-spacing:.04em}.footer-socials{display:flex;gap:.5rem}#chatbot-container{position:fixed;bottom:2rem;right:2rem;z-index:500}.chat-toggle-btn{width:52px;height:52px;border-radius:50%;background:var(--accent);color:var(--bg);border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px #a78bfa80;transition:all var(--mid)}.chat-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 32px #a78bfab3}.chat-window{position:absolute;bottom:calc(100% + 1rem);right:0;width:340px;max-height:500px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0006;transition:opacity var(--mid),transform var(--mid)}.chat-window.hidden{opacity:0;pointer-events:none;transform:translateY(8px) scale(.98)}.chat-window.active{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:var(--bg-raised);border-bottom:1px solid var(--border)}.chat-header-info{display:flex;align-items:center;gap:.75rem}.chat-avatar{width:32px;height:32px;background:var(--accent-dim);border:1px solid rgba(167,139,250,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:.9rem}.chat-header h4{font-family:var(--font-mono);font-size:.82rem;color:var(--text)}.chat-status{font-family:var(--font-mono);font-size:.65rem;color:var(--text-faint);display:flex;align-items:center;gap:.35rem}.status-dot{width:6px;height:6px;background:#28c840;border-radius:50%;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.chat-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-faint);border-radius:var(--radius);transition:all var(--fast);font-size:1rem}.chat-close:hover{color:var(--text);background:var(--accent-dim)}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.message{max-width:90%;padding:.65rem .9rem;border-radius:var(--radius);font-size:.85rem;line-height:1.5}.message.bot{background:var(--bg-raised);color:var(--text-muted);align-self:flex-start;border:1px solid var(--border)}.message.user{background:var(--accent-dim);color:var(--accent);align-self:flex-end;border:1px solid rgba(167,139,250,.2)}.options-grid{display:flex;flex-direction:column;gap:.4rem;align-self:stretch}.chat-option-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem;text-align:left;transition:all var(--fast)}.chat-option-btn svg{width:14px;height:14px;flex-shrink:0}.chat-option-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.chat-link-card{display:flex;align-items:center;justify-content:space-between;padding:.75rem .9rem;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.8rem;transition:all var(--fast)}.chat-link-card:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.card-inner{display:flex;align-items:center;gap:.5rem}.card-icon svg{width:14px;height:14px}.card-arrow svg{width:12px;height:12px}.typing-indicator{display:flex;gap:4px;padding:.75rem .9rem;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);align-self:flex-start}.typing-dot{width:5px;height:5px;background:var(--text-faint);border-radius:50%;animation:typing 1.4s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat-input-area{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-top:1px solid var(--border)}.chat-input{flex:1;padding:.5rem .75rem;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:.8rem;outline:none;transition:border-color var(--fast)}.chat-input:focus{border-color:var(--accent)}.chat-send{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius);transition:all var(--fast)}.chat-send:hover{transform:scale(1.05)}.chat-send svg{width:14px;height:14px}.back-to-top{position:fixed;bottom:6rem;right:2rem;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-faint);z-index:400;opacity:0;pointer-events:none;transition:all var(--mid)}.back-to-top.visible{opacity:1;pointer-events:all}.back-to-top:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:var(--space-md)}.page-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem;cursor:none;transition:all var(--fast)}.page-btn:hover,.page-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.text-accent{color:var(--accent)}.font-mono{font-family:var(--font-mono)}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr}.hero-stats{grid-template-columns:repeat(3,1fr)}#chatbot-container{bottom:1rem;right:1rem}}.header-logo{display:inline-flex;align-items:baseline;gap:0;font-family:var(--font-mono);font-size:.85rem;font-weight:500;color:var(--text);letter-spacing:.02em;transition:color var(--fast);white-space:nowrap;text-decoration:none}.header-logo:hover{color:var(--accent)}.logo-prefix,.logo-suffix{color:var(--accent);opacity:.7}.logo-name{color:var(--text);transition:color var(--fast);display:inline-block;min-width:2ch}.header-logo:hover .logo-name{color:var(--accent)}.scramble-char{display:inline-block;color:var(--accent);opacity:.5;animation:char-flicker .08s step-end infinite}@keyframes char-flicker{0%,to{opacity:.5}50%{opacity:1}}.tech-bars{display:none!important}.project-tech{width:100%}.project-tech-bar{display:flex;height:12px;width:100%;border-radius:6px;margin-bottom:1rem;background-color:var(--skill-bg);overflow:visible;box-shadow:inset 0 1px 3px #0003;position:relative}.project-tech-bar>.tech-segment:first-child{border-top-left-radius:6px;border-bottom-left-radius:6px}.project-tech-bar>.tech-segment:last-child{border-top-right-radius:6px;border-bottom-right-radius:6px}.tech-segment{height:100%;width:0;transition:width 1s cubic-bezier(.4,0,.2,1),filter .2s ease;position:relative;cursor:help}.tech-segment:hover{filter:brightness(1.25);z-index:2}.tech-segment:before,.tech-segment:after{position:absolute;left:50%;transform:translate(-50%);opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;pointer-events:none;z-index:20}.tech-segment:before{content:attr(data-tooltip);bottom:18px;background-color:#0a0a0a;color:#fff;padding:4px 8px;border-radius:4px;font-family:var(--font-mono);font-size:.75rem;white-space:nowrap;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 10px #0006}body.light-mode .tech-segment:before{background-color:#162447}.tech-segment:after{content:"";bottom:13px;border:5px solid transparent;border-top-color:#0a0a0a}body.light-mode .tech-segment:after{border-top-color:#162447}.tech-segment:hover:before,.tech-segment:hover:after{opacity:1;visibility:visible}.project-tech-icons{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;align-items:center;margin-top:.75rem}.tech-icon-item{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--text-muted)}.tech-icon-item i{font-size:1rem}.color-default{background-color:#8a8a8a}.color-angular{background-color:#dd0031}.color-asp\.net,.color-aspnet{background-color:#512bd4}.color-aws{background-color:#f90}.color-azure{background-color:#0078d4}.color-bash{background-color:#4eaa25}.color-bootstrap{background-color:#7952b3}.color-c{background-color:#a8b9cc}.color-c\+\+,.color-cplusplus{background-color:#00599c}.color-c\#,.color-csharp{background-color:#9b4f96}.color-css{background-color:#1572b6}.color-dart{background-color:#0175c2}.color-django{background-color:#092e20}.color-docker{background-color:#2496ed}.color-dotnet{background-color:#512bd4}.color-egui{background-color:#b22222}.color-expo{background-color:#000020}.color-express{background-color:#333}.color-firebase{background-color:#ffca28}.color-flask{background-color:#3d7a4a}.color-flutter{background-color:#02569b}.color-git{background-color:#f05032}.color-go{background-color:#00add8}.color-googlecloud{background-color:#4285f4}.color-graphql{background-color:#e10098}.color-html{background-color:#e34f26}.color-java{background-color:#f89820}.color-javascript{background-color:#f7df1e}.color-jest{background-color:#c21325}.color-jquery{background-color:#0769ad}.color-jwt{background-color:#d63031}.color-kotlin{background-color:#7f52ff}.color-kubernetes{background-color:#326ce5}.color-laravel{background-color:#ff2d20}.color-linux{background-color:#fcc624}.color-lua{background-color:#2c2d72}.color-machine-learning{background-color:#ff6f00}.color-matplotlib{background-color:#8b0000}.color-mongodb{background-color:#47a248}.color-mysql{background-color:#4479a1}.color-next\.js,.color-nextjs{background-color:#444}.color-nginx{background-color:#009639}.color-nlp{background-color:#6c3483}.color-node\.js,.color-nodejs{background-color:#393}.color-numpy{background-color:#0152c1}.color-pandas{background-color:#150458}.color-php{background-color:#777bb4}.color-postgresql{background-color:#4169e1}.color-powershell{background-color:#5391fe}.color-python{background-color:#3776ab}.color-react{background-color:#20a7db}.color-react-native{background-color:#61dafb}.color-redis{background-color:#dc382d}.color-redux{background-color:#764abc}.color-ruby{background-color:#cc342d}.color-rust{background-color:#de3423}.color-sass{background-color:#c69}.color-sql-server{background-color:#cc2927}.color-sqlite{background-color:#003b57}.color-svelte{background-color:#ff3e00}.color-swift{background-color:#f05138}.color-tailwind,.color-tailwindcss{background-color:#38b2ac}.color-tauri{background-color:#ffc131}.color-tensorflow\.js,.color-tensorflowjs{background-color:#ff6f00}.color-tkinter{background-color:#3776ab}.color-typescript{background-color:#3178c6}.color-vuejs{background-color:#4fc08d}.color-webpack{background-color:#8dd6f9}.color-yaml{background-color:#cb171e}.color-zustand{background-color:#764abc}
