:root{--bg: #f5f7fb;--card-bg: #ffffff;--card-bg-hover: #fbfbff;--border: rgba(15, 23, 42, .1);--text: #0f172a;--muted: #5b6577;--accent: #4f46e5;--accent-2: #06b6d4;--accent-contrast: #ffffff;--media-bg: #eef1f8;--tag-bg: rgba(79, 70, 229, .07);--tag-border: rgba(79, 70, 229, .22);--nav-bg: rgba(245, 247, 251, .75);--shadow: rgba(30, 41, 59, .12);--gradient: linear-gradient(135deg, var(--accent), var(--accent-2));--font-display: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden}body{margin:0;overflow-x:hidden;background:var(--bg);color:var(--text);font-family:var(--font-body)}.bg-canvas-host{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none}.bg-canvas-host canvas{display:block;width:100%;height:100%;opacity:.8}.bg-canvas-host--paused{display:none}.page{max-width:880px;margin:0 auto;padding:0 24px 48px}section{position:relative;padding:56px 0;border-bottom:1px solid var(--border)}section:last-of-type{border-bottom:none}h1,h2,h3{font-family:var(--font-display)}h1{font-size:clamp(2.1rem,4.5vw,2.9rem);line-height:1.1;letter-spacing:-.01em;margin:0 0 6px;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}h2{font-size:1.5rem;font-weight:600;margin:0 0 8px}h3{font-weight:600}.subtitle{color:var(--muted);margin:0 0 36px}.section-label{display:flex;align-items:center;gap:8px;margin:0 0 14px;font-family:var(--font-mono);font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.section-label:before{content:"";width:16px;height:1px;background:var(--gradient)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.reveal.in-view{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.site-nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--nav-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.site-nav .brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:.98rem;font-weight:600;letter-spacing:normal;text-transform:none;color:var(--text);text-decoration:none}.site-nav .brand:after{content:none}.brand-mark{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-family:var(--font-mono);font-size:.72rem;font-weight:700;color:var(--accent-contrast);background:var(--gradient);box-shadow:0 4px 12px -4px var(--shadow)}.site-nav .links{display:flex;gap:22px}.site-nav a{position:relative;color:var(--muted);text-decoration:none;font-family:var(--font-mono);font-size:.74rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding-bottom:2px;transition:color .15s ease}.site-nav a:after{content:"";position:absolute;left:0;right:100%;bottom:-1px;height:2px;background:var(--gradient);border-radius:2px;transition:right .2s ease}.site-nav a:hover{color:var(--accent)}.site-nav a.active{color:var(--text)}.site-nav a.active:after{right:0}.spaceship-toggle{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text);padding:8px 16px 8px 14px;border:1px solid transparent;border-radius:999px;background:linear-gradient(var(--card-bg),var(--card-bg)) padding-box,var(--gradient) border-box;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .2s ease,color .15s ease,opacity .15s ease}.spaceship-toggle-icon{font-size:.95em;line-height:1}.spaceship-toggle:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 22px -10px var(--shadow)}.spaceship-toggle:active:not(:disabled){transform:translateY(0)}.spaceship-toggle:disabled{cursor:default;opacity:.6}.spaceship-toggle:disabled:hover{transform:none;box-shadow:none}.spaceship-toggle:disabled .spaceship-toggle-icon{animation:spaceship-toggle-pulse 1.1s ease-in-out infinite}.spaceship-toggle[aria-pressed=true]{color:var(--accent-contrast);background:var(--gradient);box-shadow:0 8px 20px -8px #4f46e58c}.spaceship-toggle[aria-pressed=true]:hover:not(:disabled){box-shadow:0 12px 26px -8px #4f46e599}@keyframes spaceship-toggle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.82)}}@media(prefers-reduced-motion:reduce){.spaceship-toggle{transition:none}.spaceship-toggle:disabled .spaceship-toggle-icon{animation:none}}.bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;pointer-events:none;background-image:linear-gradient(rgba(15,23,42,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.05) 1px,transparent 1px);background-size:34px 34px;-webkit-mask-image:radial-gradient(ellipse 70% 65% at 25% 15%,#000 40%,transparent 88%);mask-image:radial-gradient(ellipse 70% 65% at 25% 15%,#000 40%,transparent 88%)}.bg-glow{position:fixed;z-index:-2;width:460px;height:460px;border-radius:50%;filter:blur(100px);opacity:.28;pointer-events:none}.bg-glow-1{top:-160px;left:-140px;background:var(--accent)}.bg-glow-2{bottom:-180px;right:-160px;background:var(--accent-2)}.hero-section{padding:76px 0 64px}.eyebrow{display:inline-flex;align-items:center;gap:8px;margin:0 0 16px;font-family:var(--font-mono);font-size:.76rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 0 3px #06b6d42e;animation:eyebrow-pulse 2.2s ease-in-out infinite}@keyframes eyebrow-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}@media(prefers-reduced-motion:reduce){.eyebrow-dot{animation:none}}.about{position:relative;z-index:1;display:flex;align-items:center;gap:36px}.avatar-wrap{position:relative;flex-shrink:0;width:120px;height:120px;border-radius:26px;padding:3px;background:var(--gradient);box-shadow:0 16px 32px -14px var(--shadow)}.avatar{display:block;width:100%;height:100%;border-radius:23px;object-fit:cover;background:var(--card-bg)}.avatar-scan{position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:23px;overflow:hidden;pointer-events:none}.avatar-scan:after{content:"";position:absolute;left:0;right:0;height:40%;background:linear-gradient(180deg,transparent,rgba(255,255,255,.55),transparent);animation:avatar-scan-move 3.2s ease-in-out infinite}@keyframes avatar-scan-move{0%{top:-40%}to{top:100%}}@media(prefers-reduced-motion:reduce){.avatar-scan:after{animation:none;display:none}}.about-body h1{margin-top:0}.about-body .bio{color:var(--muted);line-height:1.6;margin:8px 0 16px;max-width:52ch}.handle{color:var(--muted);font-family:var(--font-mono);font-size:.88rem;margin:0}.pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.78rem;color:var(--text);background:#fff9;border:1px solid var(--tag-border);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:5px 12px;border-radius:999px}.pill:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gradient);flex-shrink:0}.cta-row{display:flex;flex-wrap:wrap;gap:12px}.btn{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;font-weight:600;text-decoration:none;padding:10px 22px;border-radius:999px;border:1px solid transparent;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,opacity .15s ease}.btn-primary{color:var(--accent-contrast);background:var(--gradient);box-shadow:0 10px 24px -8px #4f46e58c}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -8px #4f46e599}.btn-ghost{color:var(--text);background:linear-gradient(var(--card-bg),var(--card-bg)) padding-box,var(--gradient) border-box;border:1px solid transparent}.btn-ghost:hover{transform:translateY(-2px);box-shadow:0 10px 22px -10px var(--shadow)}.skill-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.skill-group{position:relative;padding:22px 20px;border-radius:16px;background:var(--card-bg);border:1px solid var(--border);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.skill-group:hover{transform:translateY(-3px);border-color:var(--tag-border);box-shadow:0 16px 32px -14px var(--shadow)}.skill-icon{display:inline-flex;font-size:1.3rem;margin-bottom:10px}.skill-group h3{font-size:.95rem;margin:0 0 12px;color:var(--text)}.skill-group h3:before{content:"// ";font-family:var(--font-mono);font-weight:400;color:var(--accent-2)}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-family:var(--font-mono);font-size:.7rem;color:var(--accent);background:var(--tag-bg);border:1px solid var(--tag-border);border-left:2px solid var(--accent-2);padding:2px 8px;border-radius:4px}.project-marquee{position:relative;overflow:hidden;margin-bottom:36px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}.marquee-track{display:flex;width:max-content;gap:14px;animation:marquee-scroll 24s linear infinite}.project-marquee:hover .marquee-track{animation-play-state:paused}.marquee-chip{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font-family:var(--font-mono);font-size:.82rem;font-weight:500;padding:9px 18px;border-radius:999px;color:var(--text);background:var(--card-bg);border:1px solid var(--border)}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.card{position:relative;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;box-shadow:0 1px 2px var(--shadow);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.card:hover{transform:translateY(-4px);border-color:var(--tag-border);background:var(--card-bg-hover);box-shadow:0 20px 40px -18px #4f46e559}.card:hover:before{transform:scaleX(1)}.card-media{height:160px;background:var(--media-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.card-media img{width:100%;height:100%;object-fit:cover}.card-media.icon-only img{width:64px;height:64px;object-fit:contain}.card-body{padding:18px 20px 20px}.card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin:0 0 8px;display:flex;align-items:center;gap:8px}.card-desc{color:var(--muted);font-size:.92rem;line-height:1.5;margin:0 0 14px}.card-link{display:inline-flex;align-items:center;gap:4px;margin-top:14px;font-family:var(--font-mono);font-size:.82rem;font-weight:600;color:var(--accent)}.card-link-arrow{display:inline-block;transition:transform .18s ease}.card:hover .card-link-arrow{transform:translate(4px)}.contact-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.contact-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;font-size:.85rem;font-weight:500;color:var(--text);background:var(--card-bg);border:1px solid var(--border);padding:20px 12px;border-radius:14px;text-decoration:none;transition:border-color .15s ease,color .15s ease,transform .15s ease,box-shadow .15s ease}.contact-icon{font-size:1.5rem;transition:transform .18s ease}.contact-link span:last-child{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.contact-link:hover{border-color:var(--tag-border);transform:translateY(-3px);box-shadow:0 16px 30px -16px #4f46e566}.contact-link:hover .contact-icon{transform:scale(1.15)}.contact-link:hover span:last-child{color:var(--accent)}footer{padding:32px 0;color:var(--muted);font-family:var(--font-mono);font-size:.78rem;text-align:center}footer a{color:var(--accent)}@media(max-width:560px){.about{flex-direction:column;align-items:flex-start;text-align:left}}@media(max-width:480px){.site-nav{padding:14px 16px}.site-nav .brand{font-size:.92rem}.site-nav .links{gap:12px}.site-nav a{font-size:.68rem}.spaceship-toggle{padding:8px;gap:0;aspect-ratio:1}.spaceship-toggle-icon{font-size:1rem}.spaceship-toggle-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page{padding:0 16px 40px}section{padding:40px 0}.hero-section{padding:48px 0 40px}.hero-glow{width:260px;height:260px}}@media(max-width:360px){.site-nav{padding:12px 14px}.site-nav .brand{font-size:.82rem;gap:6px}.brand-mark{width:24px;height:24px;font-size:.62rem}.site-nav .links{gap:8px}.site-nav a{font-size:.6rem}}.chat-fab-wrap{position:fixed;right:24px;bottom:24px;z-index:50;display:flex;align-items:center;gap:10px;animation:chat-fab-in .4s ease .6s both}.chat-fab-wrap--hidden{display:none}.chat-fab-tooltip{background:var(--card-bg);color:var(--text);border:1px solid var(--border);padding:6px 12px;border-radius:8px;font-size:.82rem;white-space:nowrap;box-shadow:0 4px 14px #0000001f;opacity:0;transform:translate(6px);pointer-events:none;transition:opacity .15s ease,transform .15s ease}.chat-fab-wrap:hover .chat-fab-tooltip{opacity:1;transform:translate(0)}.chat-fab{width:56px;height:56px;flex-shrink:0;border-radius:50%;border:1px solid var(--border);background:var(--accent);color:#fff;font-size:1.4rem;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 20px #00000040,0 0 #7c9bff66;transition:transform .15s ease,box-shadow .15s ease}.chat-fab:hover{transform:scale(1.06)}@keyframes chat-fab-in{0%{opacity:0;transform:translateY(12px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){.chat-fab-wrap{animation:none}}.chat-panel{position:fixed;top:79px;right:16px;bottom:16px;z-index:60;width:min(460px,calc(100vw - 32px));border-radius:20px;background:#ffffffa8;backdrop-filter:blur(28px) saturate(160%);-webkit-backdrop-filter:blur(28px) saturate(160%);border:1px solid rgba(255,255,255,.5);box-shadow:0 24px 60px -20px #0f172a59;display:flex;flex-direction:column;overflow:hidden;transform:translate(calc(100% + 24px));transition:transform .25s ease}.chat-panel.open{transform:translate(0)}@media(max-width:560px){.chat-panel{top:0;right:0;bottom:0;width:100vw;border-radius:0}}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-header h2{font-size:1rem;margin:0}.chat-close{background:none;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer}.chat-close:hover{color:var(--accent)}.chat-status{flex-shrink:0;padding:12px 18px 14px;font-family:var(--font-mono, ui-monospace, monospace);background:linear-gradient(180deg,rgba(79,70,229,.06),transparent);border-bottom:1px solid var(--border);display:none}.chat-status.visible{display:block}.chat-status-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.chat-status-dot{width:7px;height:7px;flex-shrink:0;border-radius:50%;background:var(--gradient, var(--accent))}.chat-status.loading .chat-status-dot{animation:chat-status-pulse 1.6s ease-in-out infinite}.chat-status.error .chat-status-dot{background:#ef4444}@keyframes chat-status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.7)}}.chat-status-label{flex:1;font-size:.72rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.chat-status.error .chat-status-label{color:#ef4444}.chat-status-percent{font-size:.82rem;font-weight:600;font-variant-numeric:tabular-nums;min-width:3ch;text-align:right;background:var(--gradient, var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.chat-status-bar{position:relative;height:6px;border-radius:999px;background:var(--border);overflow:hidden}.chat-status-bar-fill{position:relative;height:100%;border-radius:inherit;background:var(--gradient, var(--accent));box-shadow:0 0 10px -1px #4f46e599;width:0%;transition:width .25s ease;overflow:hidden}.chat-status.loading .chat-status-bar-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:chat-status-shimmer 1.4s linear infinite}@keyframes chat-status-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.chat-status-bytes{margin-top:6px;font-size:.68rem;color:var(--muted)}.chat-status-files{margin-top:8px;display:flex;flex-direction:column;gap:4px;max-height:96px;overflow-y:auto}.chat-status-file{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:linear-gradient(90deg,var(--tag-bg) var(--file-pct, 0%),transparent var(--file-pct, 0%));font-size:.68rem;color:var(--muted);transition:background .2s ease}.chat-status-file.done{color:var(--accent);border-color:var(--tag-border)}.chat-status-file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-status-file-percent{flex-shrink:0;min-width:2.5ch;text-align:right;font-variant-numeric:tabular-nums}@media(prefers-reduced-motion:reduce){.chat-status-dot,.chat-status.loading .chat-status-bar-fill:after{animation:none}}.chat-messages{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:12px}.chat-message{max-width:90%;padding:10px 14px;border-radius:12px;font-size:.88rem;line-height:1.5;white-space:pre-wrap}.chat-message.user{align-self:flex-end;background:var(--accent);color:#fff}.chat-message.assistant{align-self:flex-start;background:var(--tag-bg);border:1px solid var(--tag-border);color:var(--text)}.chat-message img{max-width:100%;border-radius:8px;margin-top:6px;display:block}.chat-footer{flex-shrink:0;border-top:1px solid var(--border);padding:12px 14px;display:flex;flex-direction:column;gap:8px}.chat-image-preview{display:none;align-items:center;gap:8px;font-size:.78rem;color:var(--muted)}.chat-image-preview.visible{display:flex}.chat-image-preview img{width:36px;height:36px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.chat-image-preview button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.78rem;text-decoration:underline}.chat-input-row{display:flex;align-items:flex-end;gap:8px}.chat-input-row textarea{flex:1;resize:none;min-height:40px;max-height:120px;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;font-size:.88rem}.chat-attach,.chat-send{flex-shrink:0;width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem}.chat-send{background:var(--accent);border-color:var(--accent);color:#fff}.chat-input-row textarea:disabled,.chat-attach:disabled,.chat-send:disabled{opacity:.5;cursor:not-allowed}
