:root{--paper: #F4ECE0;--paper-soft: #FAF4EA;--paper-warm: #EFE3D2;--ink: #1F1F2E;--ink-2: #3A3A4C;--ink-muted: #6E6E80;--ink-line: rgba(31,31,46,.14);--ink-line-soft:rgba(31,31,46,.07);--terracotta: #C8553D;--terracotta-2: #E07A5F;--mustard: #E0A24C;--sage: #6B8E5A;--plum: #5A4E7C;--sky: #5B8FB9;--accent: var(--terracotta);--accent-2: var(--mustard);--font-sans: "Geist", "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-serif:"Instrument Serif", "Times New Roman", serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;--ease: cubic-bezier(.22, 1, .36, 1)}[data-theme=terracotta]{--accent: #C8553D;--accent-2: #E0A24C}[data-theme=plum]{--accent: #5A4E7C;--accent-2: #E0A24C}[data-theme=violet]{--accent: #6D5BC6;--accent-2: #4A7BC8}[data-theme=sage]{--accent: #6B8E5A;--accent-2: #E07A5F}[data-theme=sky]{--accent: #4F7E9F;--accent-2: #E0A24C}[data-theme=mustard]{--accent: #C7861F;--accent-2: #6B8E5A}[data-theme=ink]{--accent: #1F1F2E;--accent-2: #C8553D}[data-theme=rose]{--accent: #C04A6A;--accent-2: #E0A24C}[data-theme=emerald]{--accent: #2A8A5E;--accent-2: #E07A5F}[data-theme=amber]{--accent: #D9831A;--accent-2: #5A4E7C}[data-theme=teal]{--accent: #2E8B86;--accent-2: #E0A24C}[data-theme=crimson]{--accent: #9C2A3B;--accent-2: #E0A24C}[data-mode=dark]{--paper: #0E0E14;--paper-soft: #15151F;--paper-warm: #1E1E2A;--ink: #F0EAE0;--ink-2: #BFB9C8;--ink-muted: #7E7A88;--ink-line: rgba(240,234,224,.13);--ink-line-soft:rgba(240,234,224,.06)}[data-mode=dark] body:before{opacity:.55;mix-blend-mode:screen;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.85   0 0 0 0 0.85   0 0 0 0 1   0 0 0 0.05 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}[data-mode=dark] .nav{background:#0e0e14c7}[data-mode=dark] .blob{opacity:.35!important;filter:blur(100px)}[data-mode=dark] .nav-cta{background:var(--accent);color:var(--paper)}[data-mode=dark] .nav-cta:hover{background:var(--ink);color:var(--paper)}[data-mode=dark] .btn-primary{background:var(--accent);color:#fff}[data-mode=dark] .btn-primary:hover{background:var(--ink);color:var(--paper)}[data-mode=dark] .gh-link:hover{background:var(--accent);color:#fff;border-color:var(--accent)}[data-mode=dark] .work-card.tone-ink{background:#0a0a12!important}[data-mode=dark] .work-card.tone-ink .body{background:#0a0a12!important;border-top-color:#ffffff0d}[data-mode=dark] .work-card.tone-ink .tone{background:linear-gradient(135deg,#1f1d2e,#0a0a12)!important}[data-mode=dark] .work-stack span,[data-mode=dark] .project-stack span{background:#ffffff0a;border-color:#ffffff14}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-weight:400;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}::selection{background:var(--accent);color:var(--paper)}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.4;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.12   0 0 0 0 0.12   0 0 0 0 0.18   0 0 0 0.08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:multiply}.wrap{position:relative;z-index:1;max-width:1280px;margin:0 auto;padding-inline:clamp(20px,5vw,64px)}.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);background:#f4ece0c7;border-bottom:1px solid var(--ink-line-soft)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding-block:18px}.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-serif);font-size:22px;font-style:italic;letter-spacing:-.01em}.brand-mark{width:28px;height:28px;border-radius:50%;background:var(--accent);display:inline-flex;align-items:center;justify-content:center;color:var(--paper);font-family:var(--font-sans);font-style:normal;font-weight:700;font-size:12px;letter-spacing:.5px;transition:background .3s var(--ease)}.brand-dot{color:var(--accent)}.nav-links{display:flex;gap:28px;list-style:none;font-size:14px;font-weight:500}.nav-links a{color:var(--ink-2);transition:color .25s var(--ease);position:relative}.nav-links a:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left center;transition:transform .3s var(--ease)}.nav-links a:hover{color:var(--ink)}.nav-links a:hover:after{transform:scaleX(1)}.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:var(--ink);color:var(--paper);font-size:13px;font-weight:600;transition:transform .2s var(--ease),background .2s var(--ease)}.nav-cta:hover{background:var(--accent);transform:translateY(-1px)}.nav-cta .dot{width:7px;height:7px;border-radius:50%;background:#7bd389;box-shadow:0 0 0 3px #7bd38940}.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-2);transition:color .2s var(--ease),gap .2s var(--ease)}.back-link:hover{color:var(--accent);gap:12px}.section{padding-block:clamp(70px,10vw,140px);position:relative}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:56px;padding-bottom:24px;border-bottom:1px solid var(--ink-line)}.section-num{font-family:var(--font-mono);font-size:12px;color:var(--ink-muted);letter-spacing:.14em;text-transform:uppercase}.section-num .accent{color:var(--accent)}.section-title{font-family:var(--font-serif);font-size:clamp(38px,5.5vw,68px);font-weight:400;line-height:1;letter-spacing:-.02em}.section-title .it{font-style:italic;color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:999px;font-size:14px;font-weight:600;transition:transform .2s var(--ease),background .2s var(--ease),color .2s var(--ease)}.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:hover{background:var(--accent);transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink-line)}.btn-ghost:hover{background:var(--paper-warm);border-color:var(--ink)}.btn-arrow{transition:transform .2s var(--ease)}.btn:hover .btn-arrow{transform:translate(2px,-2px)}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;pointer-events:none;z-index:-1}.blob-1{width:360px;height:360px;background:var(--accent-2);top:-60px;right:-100px;opacity:.35}.blob-2{width:320px;height:320px;background:var(--terracotta-2);bottom:-120px;left:-80px;opacity:.28}.blob-3{width:280px;height:280px;background:var(--sage);top:30%;right:-120px;opacity:.22}.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}.reveal.in{opacity:1;transform:translateY(0)}.theme-picker{position:fixed;bottom:20px;right:20px;z-index:100;display:flex;align-items:center;gap:8px;padding:8px 10px;background:#f4ece0eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--ink-line);border-radius:999px;box-shadow:0 18px 40px -20px #1f1f2e59;flex-wrap:wrap;max-width:360px;justify-content:flex-end}.theme-picker .label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);padding-left:6px;padding-right:4px}.theme-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s var(--ease),border-color .2s var(--ease);position:relative}.theme-swatch:hover{transform:scale(1.1)}.theme-swatch[data-active=true]{border-color:var(--ink);transform:scale(1.05)}.footer{margin-top:clamp(64px,9vw,120px);padding-top:28px;border-top:1px solid var(--ink-line);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-family:var(--font-mono);font-size:12px;color:var(--ink-muted)}.nav-burger{display:none;align-items:center;justify-content:center;width:38px;height:38px;padding:0;background:transparent;border:1px solid var(--ink-line);border-radius:10px;color:var(--ink);cursor:pointer}.nav-burger:hover{background:var(--paper-soft)}.nav-burger .bars{display:inline-flex;flex-direction:column;gap:4px;width:16px}.nav-burger .bars span{display:block;height:2px;background:currentColor;border-radius:2px;transition:transform .25s var(--ease),opacity .2s var(--ease)}.nav.open .nav-burger .bars span:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav.open .nav-burger .bars span:nth-child(2){opacity:0}.nav.open .nav-burger .bars span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}@media (max-width: 640px){.nav-burger{display:inline-flex}.nav-inner{position:relative;gap:12px}.nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--ink-line);box-shadow:0 16px 30px -20px #00000059;padding:6px 24px 16px;display:none}.nav.open .nav-links{display:flex}.nav-links li{width:100%;padding:12px 0;border-bottom:1px dashed var(--ink-line)}.nav-links li:last-child{border-bottom:0}.nav-links a{font-size:15px;display:block}.nav-links a:after{display:none}.nav-cta{padding:7px 12px;font-size:12px}.theme-picker{bottom:14px;right:14px;padding:6px 8px}.theme-picker .label{display:none}.theme-swatch{width:20px;height:20px}[data-mode=dark] .nav-links{background:#0e0e14}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}body.has-cursor,body.has-cursor a,body.has-cursor button,body.has-cursor input,body.has-cursor textarea{cursor:none!important}.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;will-change:transform}.cursor-dot{width:8px;height:8px;background:var(--accent);margin:-4px 0 0 -4px;box-shadow:0 0 0 1px color-mix(in oklab,var(--paper) 60%,transparent),0 0 14px color-mix(in oklab,var(--accent) 55%,transparent);transition:background .25s var(--ease)}.cursor-ring{width:40px;height:40px;border:1.5px solid var(--accent);margin:-20px 0 0 -20px;box-shadow:0 0 0 1px color-mix(in oklab,var(--paper) 50%,transparent);transition:width .25s var(--ease),height .25s var(--ease),margin .25s var(--ease),border-color .25s var(--ease)}body.cursor-hover .cursor-ring{width:64px;height:64px;margin:-32px 0 0 -32px;border-color:var(--accent)}body.cursor-hover .cursor-dot{background:var(--accent);box-shadow:0 0 0 1px color-mix(in oklab,var(--paper) 60%,transparent),0 0 18px color-mix(in oklab,var(--accent) 70%,transparent)}.magnetic{display:inline-flex}.magnetic-inner{display:inline-flex;transition:transform .4s var(--ease)}.mesh-bg{position:absolute;top:-30%;right:-30%;bottom:-30%;left:-30%;z-index:-1;pointer-events:none;opacity:.55;filter:blur(70px) saturate(110%);overflow:hidden}.mesh-bg:before,.mesh-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:conic-gradient(from 0deg,color-mix(in oklab,var(--accent) 80%,transparent),color-mix(in oklab,var(--accent-2) 60%,transparent),color-mix(in oklab,var(--sage) 50%,transparent),color-mix(in oklab,var(--accent) 80%,transparent));border-radius:50%;animation:mesh-spin 28s linear infinite}.mesh-bg:after{background:conic-gradient(from 180deg,color-mix(in oklab,var(--mustard) 60%,transparent),color-mix(in oklab,var(--accent) 70%,transparent),color-mix(in oklab,var(--sky) 55%,transparent),color-mix(in oklab,var(--mustard) 60%,transparent));animation:mesh-spin 42s linear infinite reverse;mix-blend-mode:screen;opacity:.7}@keyframes mesh-spin{to{transform:rotate(360deg)}}[data-mode=dark] .mesh-bg{opacity:.4;filter:blur(80px) saturate(130%)}.browser-frame{display:flex;flex-direction:column;border-radius:12px;overflow:hidden;background:var(--paper-soft);border:1px solid var(--ink-line);box-shadow:0 18px 40px -20px #00000073}.work-card .tone .browser-frame{height:100%}.work-card .tone .browser-frame img{flex:1;min-height:0;width:100%;object-fit:cover;object-position:top left;border-radius:0;border:none;box-shadow:none}.browser-frame-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--paper-warm);border-bottom:1px solid var(--ink-line-soft)}.browser-frame-dots{display:flex;gap:6px}.browser-frame-dot{width:10px;height:10px;border-radius:50%;background:var(--ink-line)}.browser-frame-dot:nth-child(1){background:#ff5f57}.browser-frame-dot:nth-child(2){background:#febc2e}.browser-frame-dot:nth-child(3){background:#28c840}.browser-frame-url{flex:1;text-align:center;font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);background:color-mix(in oklab,var(--ink) 5%,transparent);padding:4px 12px;border-radius:6px;margin-left:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.browser-frame img,.browser-frame video{display:block;width:100%}[data-mode=dark] .browser-frame{background:#16161e;border-color:#ffffff14}[data-mode=dark] .browser-frame-bar{background:#1e1e2a}.portrait-slot{position:relative;display:inline-block;border-radius:24px;background:repeating-linear-gradient(45deg,transparent 0 14px,color-mix(in oklab,var(--ink) 6%,transparent) 14px 15px),linear-gradient(135deg,color-mix(in oklab,var(--accent) 14%,var(--paper-warm)) 0%,var(--paper-warm) 100%);border:2px dashed color-mix(in oklab,var(--accent) 45%,var(--ink-line));overflow:hidden;transition:transform .4s var(--ease),border-color .3s var(--ease)}.portrait-slot:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 30%,color-mix(in oklab,var(--accent-2) 45%,transparent),transparent 60%);pointer-events:none}.portrait-slot:hover{transform:scale(1.02);border-color:var(--accent)}.portrait-slot img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:22px}.portrait-slot-empty{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;height:100%;padding:24px;font-family:var(--font-mono);text-align:center;color:color-mix(in oklab,var(--ink) 70%,var(--paper))}.portrait-slot-empty svg{width:36px;height:36px;opacity:.7;margin-bottom:4px}.portrait-slot-empty .ps-label{font-size:11px;text-transform:uppercase;letter-spacing:.16em;font-weight:500}.portrait-slot-empty .ps-hint{font-size:11px;opacity:.65;letter-spacing:.02em;text-transform:none}.rotate-word{display:inline-block;position:relative;vertical-align:baseline;overflow:hidden;height:1em;line-height:1}.rw-track{display:block;line-height:inherit}.rw-item{display:block;height:1em;line-height:inherit;font-style:italic;color:var(--accent);white-space:nowrap}.title-line{display:block;overflow:hidden;padding-bottom:.16em;margin-bottom:-.16em}.title-word{display:inline-block;transform:translateY(110%);opacity:0;animation:title-up .9s var(--ease) forwards;animation-delay:calc(var(--i, 0) * 80ms + .2s)}@keyframes title-up{to{transform:translateY(0);opacity:1}}@media (prefers-reduced-motion: reduce){.title-word{animation:none;transform:none;opacity:1}}.now-row .when .when-rel{display:block;font-size:9px;opacity:.65;margin-top:2px;text-transform:none;letter-spacing:.04em}.theme-picker{background:color-mix(in oklab,var(--paper) 88%,transparent);transition:background .3s ease,border-color .3s ease,transform .4s var(--ease),opacity .3s ease;transform-origin:right center}[data-mode=dark] .theme-picker{background:#14141eeb}.theme-picker.collapsed{transform:translate(calc(100% + 16px));opacity:0;pointer-events:none}.dock-tab{position:fixed;bottom:20px;right:0;z-index:100;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--ink);color:var(--paper);border-radius:12px 0 0 12px;cursor:pointer;box-shadow:-8px 8px 24px -10px #00000040;opacity:0;transform:translate(100%);transition:opacity .3s ease,transform .3s var(--ease),background .2s ease;pointer-events:none}.dock-tab.visible{opacity:1;transform:translate(0);pointer-events:auto}.dock-tab:hover{background:var(--accent)}.dock-tab svg{width:16px;height:16px}.dock-close{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--ink-muted);font-size:16px;line-height:1;cursor:pointer;margin-left:4px;transition:color .2s,background .2s;flex-shrink:0}.dock-close:hover{color:var(--ink);background:var(--ink-line-soft)}@media (max-width: 640px){.dock-tab{bottom:14px}}.mode-toggle{width:24px;height:24px;border-radius:50%;background:var(--ink);color:var(--paper);display:inline-flex;align-items:center;justify-content:center;margin-right:6px;border:2px solid transparent;cursor:pointer;transition:transform .2s var(--ease),background .2s ease;flex-shrink:0}.mode-toggle:hover{transform:scale(1.1) rotate(-12deg)}.mode-toggle svg{width:12px;height:12px}.mode-toggle .icon-sun{display:none}.mode-toggle .icon-moon,[data-mode=dark] .mode-toggle .icon-sun{display:block}[data-mode=dark] .mode-toggle .icon-moon{display:none}.tp-divider{width:1px;height:16px;background:var(--ink-line);margin:0 4px;flex-shrink:0}.ai-widget{position:fixed;bottom:20px;left:20px;z-index:200;font-family:var(--font-sans)}.ai-toggle{position:relative;display:inline-flex;align-items:center;gap:10px;padding:12px 18px 12px 14px;border-radius:999px;background:linear-gradient(135deg,#6d5bc6,#4a7bc8);color:#fff;font-weight:600;font-size:13px;letter-spacing:.01em;cursor:pointer;box-shadow:0 0 0 1px #ffffff14 inset,0 14px 40px -10px #6d5bc68c,0 6px 20px -8px #4a7bc880;transition:transform .2s var(--ease),box-shadow .3s var(--ease)}.ai-toggle:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 0 0 1px #ffffff29 inset,0 22px 50px -10px #6d5bc6bf,0 10px 30px -8px #4a7bc899}.ai-toggle:active{transform:translateY(0) scale(.98)}.ai-toggle svg{width:18px;height:18px;stroke-width:2}.ai-toggle-pulse{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:999px;background:radial-gradient(circle,rgba(120,90,220,.5),transparent 70%);filter:blur(10px);z-index:-1;animation:ai-pulse 2.6s ease-in-out infinite;pointer-events:none}@keyframes ai-pulse{0%,to{opacity:.5;transform:scale(.92)}50%{opacity:1;transform:scale(1.08)}}.ai-panel{position:absolute;bottom:calc(100% + 12px);left:0;width:360px;max-width:calc(100vw - 40px);height:480px;max-height:calc(100vh - 120px);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#1a1730,#0f0c1f);border:1px solid rgba(120,90,220,.25);box-shadow:0 30px 80px -20px #0a061ebf,0 0 0 1px #785adc1f;display:flex;flex-direction:column;opacity:0;transform:translateY(10px) scale(.98);transform-origin:bottom left;transition:opacity .25s var(--ease),transform .25s var(--ease)}.ai-panel.open{opacity:1;transform:translateY(0) scale(1)}.ai-panel[hidden]{display:none}.ai-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(180deg,#785adc1f,#785adc0a);border-bottom:1px solid rgba(120,90,220,.15)}.ai-title{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:#f0eaff}.ai-title em{font-family:var(--font-serif);font-style:italic;color:#b4a4ff;font-size:1.1em}.ai-dot{width:8px;height:8px;border-radius:50%;background:#8674e8;box-shadow:0 0 12px #8674e8;animation:ai-dot 2s ease-in-out infinite}@keyframes ai-dot{50%{opacity:.35;transform:scale(.7)}}.ai-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;color:#f0eaff99;font-size:22px;line-height:1;border-radius:6px;cursor:pointer;transition:background .2s,color .2s}.ai-close:hover{background:#785adc26;color:#fff}.ai-chat{flex:1;padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:rgba(120,90,220,.3) transparent}.ai-chat::-webkit-scrollbar{width:4px}.ai-chat::-webkit-scrollbar-thumb{background:#785adc4d;border-radius:2px}.ai-msg{padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.5;max-width:85%;word-wrap:break-word;animation:ai-msg-in .32s var(--ease)}@keyframes ai-msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-msg-bot{background:#785adc21;color:#f0eaff;border-top-left-radius:4px;align-self:flex-start}.ai-msg-bot em{font-family:var(--font-serif);font-style:italic;color:#b4a4ff}.ai-msg-user{background:linear-gradient(135deg,#6d5bc6,#4a7bc8);color:#fff;border-top-right-radius:4px;align-self:flex-end;box-shadow:0 6px 16px -6px #6d5bc68c}.ai-typing{display:inline-flex;align-items:center;gap:5px;padding:16px 14px}.ai-typing span{width:6px;height:6px;border-radius:50%;background:#b4a4ff;animation:ai-typing 1.2s ease-in-out infinite}.ai-typing span:nth-child(2){animation-delay:.15s}.ai-typing span:nth-child(3){animation-delay:.3s}@keyframes ai-typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.ai-input-row{display:flex;gap:8px;padding:12px 14px;border-top:1px solid rgba(120,90,220,.15);background:#785adc0a}.ai-input{flex:1;background:#785adc14;border:1px solid rgba(120,90,220,.22);color:#f0eaff;font-family:inherit;font-size:13.5px;padding:10px 14px;border-radius:999px;outline:none;transition:border-color .2s,background .2s}.ai-input::placeholder{color:#f0eaff66}.ai-input:focus{border-color:#8674e8;background:#785adc1f}.ai-send{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#6d5bc6,#4a7bc8);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s var(--ease),opacity .2s;flex-shrink:0}.ai-send svg{width:14px;height:14px;stroke-width:2}.ai-send:hover{transform:scale(1.08)}.ai-send:disabled{opacity:.5;transform:none;cursor:wait}.ai-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.ai-chip{font-family:var(--font-mono);font-size:11px;padding:5px 11px;border-radius:999px;background:#785adc14;color:#b4a4ff;border:1px solid rgba(120,90,220,.2);cursor:pointer;transition:background .2s;white-space:nowrap}.ai-chip:hover{background:#785adc2e}.ai-foot{padding:8px 16px 12px;font-family:var(--font-mono);font-size:10px;color:#f0eaff59;text-align:center;letter-spacing:.04em}.work-card{position:relative;isolation:isolate}.work-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle 220px at var(--mx, 50%) var(--my, 50%),color-mix(in oklab,var(--accent) 14%,transparent),transparent 70%);opacity:0;transition:opacity .3s var(--ease);border-radius:22px;z-index:0}.work-card:hover:after{opacity:1}.work-card>*{position:relative;z-index:1}.float-dots{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.float-dot{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:.4;animation:float-dot 16s ease-in-out infinite}[data-mode=dark] .float-dot{opacity:.5;box-shadow:0 0 12px var(--accent)}@keyframes float-dot{0%,to{transform:translate(0)}25%{transform:translate(40px,-30px)}50%{transform:translate(-20px,40px)}75%{transform:translate(-40px,-20px)}}@media (max-width: 720px){.ai-widget{bottom:14px;left:14px}.ai-toggle-label{display:none}.ai-toggle{padding:12px}.ai-panel{width:calc(100vw - 28px);height:70vh}}@media (max-width: 640px){.tp-divider{display:none}}@media (prefers-reduced-motion: reduce){.ai-toggle-pulse,.ai-dot,.float-dot,.ai-msg{animation:none!important}}
