.bento-shell{--cell: 220px;--gap: 16px;max-width:1040px;margin:0 auto;padding:56px 32px 96px;background:var(--bg);color:var(--fg)}.grid-wrapper{position:relative}.grid-stage{display:block}.block{display:grid;grid-template-columns:repeat(4,var(--cell));grid-auto-rows:var(--cell);grid-auto-flow:dense;gap:var(--gap);justify-content:center}.cell{position:relative;transition:transform .32s cubic-bezier(.2,.8,.2,1)}.cell.size-1x1{grid-column:span 1;grid-row:span 1}.cell.size-2x1{grid-column:span 2;grid-row:span 1}.cell.size-2x2{grid-column:span 2;grid-row:span 2}.card{position:relative;width:100%;height:100%;border-radius:20px;background:#fff;border:1px solid var(--hairline);overflow:hidden;transition:transform .28s cubic-bezier(.2,.8,.2,1),box-shadow .28s,border-color .28s;box-shadow:0 1px 2px #18171508;cursor:pointer}.card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -20px #1817152e,0 2px 6px -2px #1817150f;border-color:#18171524}.card.dark{background:#181715;color:#fafaf7}.card.accent{background:var(--accent);color:#181715}.expand-hint{position:absolute;bottom:12px;right:12px;width:22px;height:22px;border-radius:999px;display:grid;place-items:center;background:#1817150a;color:var(--fg);opacity:0;transform:translate(4px);transition:opacity .22s,transform .22s;pointer-events:none;z-index:2}.card.dark .expand-hint{background:#ffffff14;color:#fafaf7}.card:hover .expand-hint{opacity:1;transform:translate(0)}.about{background:linear-gradient(180deg,var(--bubble-bg) 0%,#E8E4DC 100%);padding:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%}.about .avatar{width:84px;height:84px;border-radius:50%;object-fit:cover;background:#22201d;box-shadow:0 12px 30px -10px #0000004d,inset 0 0 0 1px #ffffff0f;margin-bottom:22px;transition:transform .32s cubic-bezier(.2,.8,.2,1);user-select:none;-webkit-user-drag:none}.card:hover .about .avatar{transform:translateY(-2px) scale(1.03)}.about .name-tag{font-size:11px;font-family:var(--font-mono);letter-spacing:.12em;color:var(--fg-muted);text-transform:uppercase;margin-bottom:12px}.about .headline{margin:0;font-size:36px;line-height:1.05;letter-spacing:-.03em;font-weight:600;text-wrap:balance;max-width:360px}.about .headline em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--accent)}.about .footer-row{margin-top:24px;display:flex;gap:18px;align-items:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--fg-muted);text-transform:uppercase}.social{padding:24px;display:flex;flex-direction:column;height:100%}.social .label{font-size:12px;color:var(--fg-muted);font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.social .quad{margin-top:18px;flex:1;display:grid;grid-template-columns:1fr 1fr;gap:10px}.social .quad-item{border:1px solid var(--hairline);border-radius:14px;padding:14px;display:flex;flex-direction:column;justify-content:space-between;transition:background .22s,border-color .22s,transform .22s;text-decoration:none;color:inherit}.social .quad-item:hover{background:var(--bubble-bg);border-color:#18171529;transform:translateY(-2px)}.social .quad-item .handle{font-size:11px;color:var(--fg-muted);margin-top:2px;font-family:var(--font-mono)}.social .quad-item .label-name{font-size:13px;font-weight:500}.location{display:grid;grid-template-columns:var(--cell) 1fr;height:100%}.location .map-area{position:relative}.location .info{padding:22px;display:flex;flex-direction:column;justify-content:space-between}.location .info .label{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase}.location .info h2{margin:4px 0 0;font-size:24px;font-weight:500;letter-spacing:-.02em}.location .info h2 em{font-family:var(--font-serif);font-style:italic;font-weight:400}.location .strip{display:flex;gap:16px;font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);letter-spacing:.04em}.location .strip span b{font-weight:500;color:var(--fg)}.article{padding:28px;display:flex;flex-direction:column;height:100%}.article .top{display:flex;justify-content:space-between;align-items:center}.article .pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--fg-muted);text-transform:uppercase}.article .pill .dot{width:6px;height:6px;border-radius:999px;background:var(--accent)}.article .body{flex:1;display:flex;flex-direction:column;justify-content:center;padding-right:8px}.article h3{margin:0;font-size:32px;line-height:1.05;letter-spacing:-.025em;font-weight:500;text-wrap:balance}.article h3 em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--accent)}.article p{margin:14px 0 0;font-size:13px;line-height:1.5;color:var(--fg-muted);text-wrap:pretty}.article .bottom{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:10px;color:var(--fg-muted);letter-spacing:.08em}.article .bottom .read-row{display:inline-flex;align-items:center;gap:6px}.article .bottom .read-arrow{width:16px;height:16px;border-radius:999px;background:var(--fg);color:#fff;display:inline-grid;place-items:center;font-size:9px;transition:transform .24s}.card:hover .article .bottom .read-arrow{transform:rotate(45deg)}.work{padding:22px;display:flex;flex-direction:column;justify-content:space-between;height:100%}.work .mark{width:36px;height:36px;border-radius:10px;background:var(--accent);display:grid;place-items:center;transition:transform .32s cubic-bezier(.2,.8,.2,1)}.card:hover .work .mark{transform:rotate(-8deg)}.work .role-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fafaf780}.work .role{font-size:16px;font-weight:500;margin-top:4px;letter-spacing:-.01em}.work .at{font-size:13px;color:#fafaf799;margin-top:2px;font-family:var(--font-serif);font-style:italic}.toolbox{height:100%;padding:22px;display:flex;flex-direction:column;box-sizing:border-box}.toolbox .title{margin:0 0 18px;font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted)}.toolbox .quad{flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:10px;min-height:0}.toolbox .tool{position:relative;border:1px solid var(--hairline);border-radius:14px;padding:12px;display:flex;flex-direction:column;justify-content:space-between;background:#fff;transition:background .26s,border-color .26s,transform .26s;overflow:hidden;box-sizing:border-box}.toolbox .tool:after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--tint, transparent);opacity:0;transition:opacity .28s;pointer-events:none}.toolbox .tool:hover{transform:translateY(-2px);border-color:#18171529}.toolbox .tool:hover:after{opacity:.06}.toolbox .tool .logo{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;background:var(--logo-bg, var(--bubble-bg));transition:transform .32s cubic-bezier(.2,.8,.2,1)}.toolbox .tool .logo-claude-mark{background:var(--accent)}.toolbox .tool .logo img{width:18px;height:18px;object-fit:contain;display:block;user-select:none;-webkit-user-drag:none}.toolbox .tool .logo--full{background:transparent;padding:0}.toolbox .tool .logo--full img{width:88%;height:88%;object-fit:contain;border-radius:6px}.toolbox .tool .logo img[src$="figma.svg"]{width:22px;height:22px}.toolbox .tool:hover .logo{transform:rotate(-6deg)}.toolbox .tool .meta{position:relative;z-index:1}.toolbox .tool .name{font-size:13px;font-weight:500;letter-spacing:-.01em}.toolbox .tool .role{font-size:11px;color:var(--fg-muted);margin-top:2px;font-family:var(--font-mono);letter-spacing:.02em}.interests{padding:18px;display:flex;flex-direction:column;gap:10px;height:100%}.interests .label{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-muted)}.interests .tags{display:flex;flex-wrap:wrap;gap:6px;align-content:flex-start;flex:1}.interests .tag{font-size:11px;padding:5px 9px;border-radius:999px;background:var(--bubble-bg);border:1px solid var(--hairline)}.interests .tag.hot{background:var(--accent);color:#181715;font-weight:500;border:none;font-family:var(--font-mono);letter-spacing:.02em}.contact{padding:20px;display:flex;flex-direction:column;justify-content:space-between;height:100%}.contact .big{font-size:30px;line-height:1;letter-spacing:-.025em;font-weight:600;text-wrap:balance}.contact .big em{font-family:var(--font-serif);font-style:italic;font-weight:400}.contact .email{font-size:12px;margin-top:8px;opacity:.75;font-family:var(--font-mono);letter-spacing:.02em}.contact .arrow{width:28px;height:28px;border-radius:999px;background:#181715;color:var(--accent);display:grid;place-items:center;align-self:flex-end;transition:transform .28s cubic-bezier(.2,.8,.2,1)}.card:hover .contact .arrow{transform:rotate(-12deg) scale(1.06)}.modal-backdrop{position:fixed;inset:0;background:#18171573;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:100;opacity:0;pointer-events:none;transition:opacity .28s}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{position:fixed;left:50%;top:50%;width:min(560px,92vw);transform:translate(-50%,-48%) scale(.96);background:var(--bg);border-radius:24px;padding:32px;z-index:101;box-shadow:0 40px 80px -20px #0006;opacity:0;pointer-events:none;transition:opacity .28s,transform .32s cubic-bezier(.2,.8,.2,1)}.modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}.modal.modal--article{width:min(820px,96vw);max-height:min(92vh,1000px);padding:22px 28px 20px;display:flex;flex-direction:column;box-sizing:border-box}.modal.modal--article #modal-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.modal.modal--article .modal-tag,.modal.modal--article h2{flex-shrink:0}.modal.modal--article h2{margin-bottom:12px}.modal-article-scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-right:8px;margin-right:-4px}.modal-article-prose{max-width:none}.modal-article-prose :first-child{margin-top:0}.modal.modal--article .modal-link{flex-shrink:0;margin-top:16px;padding-top:4px}.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:999px;background:var(--bubble-bg);border:1px solid var(--hairline);cursor:pointer;display:grid;place-items:center;color:var(--fg);font-size:16px;line-height:1;font-family:inherit}.modal .modal-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-muted)}.modal h2{margin:8px 0 16px;font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1.15}.modal h2 em{font-family:var(--font-serif);font-style:italic;font-weight:400}.modal p{margin:0 0 12px;font-size:15px;line-height:1.55;color:var(--fg-muted);text-wrap:pretty}.modal p strong{color:var(--fg);font-weight:650}.modal .modal-link{display:inline-block;margin-top:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--fg);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--fg-dim)}.modal .modal-link:hover{text-decoration-color:var(--fg)}@media(max-width:720px){.bento-shell{--cell: clamp(140px, 42vw, 180px);--gap: 12px;padding:32px 16px 64px}.block{grid-template-columns:repeat(2,var(--cell))}.about .headline{font-size:22px}.article h3{font-size:20px}.contact .big{font-size:22px}.location{grid-template-columns:var(--cell) 1fr}.toolbox{padding:16px}.toolbox .title{font-size:11px;margin-bottom:14px}.toolbox .quad{gap:8px}.toolbox .tool{padding:10px}.toolbox .tool .logo{width:28px;height:28px}.toolbox .tool .logo img{width:16px;height:16px}.toolbox .tool .logo img[src$="figma.svg"]{width:20px;height:20px}.toolbox .tool .logo--full img{width:88%;height:88%}.toolbox .tool .name{font-size:12px}.toolbox .tool .role{font-size:10px}.modal.modal--article{width:min(100%,96vw);max-height:90vh;padding:16px 18px 14px}}@media(prefers-reduced-motion:reduce){.card,.about .avatar,.work .mark,.contact .arrow,.article .read-arrow,.expand-hint,.toolbox .tool,.toolbox .tool .logo,.toolbox .tool:after{transition:none!important}.toolbox .tool:hover,.toolbox .tool:hover .logo{transform:none}}
