:root{--bg: #F5F5F3;--bg-card: #edf6f4;--bg-card-2: #daeae7;--text: #2d3142;--text-muted: #6b7080;--accent: #4a7c74;--accent-active: #3a6860;--border: #89B0AE45;--shadow: #2d314218;--bubble-self: #d4e8d2;--bubble-self-text: #1e2a1e;--bubble-other: #FFFFFF;--bubble-other-text: #2d3142;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-bubble: 18px;--radius-bubble-in: 18px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;--font-mono: ui-monospace, "SF Mono", Menlo, monospace;--transition: .15s cubic-bezier(.4,0,.2,1)}html[data-theme=night]{--bg: #22262f;--bg-card: #2c313b;--bg-card-2: #353b46;--text: #e8e8e4;--text-muted: #8fa8a6;--accent: #6aada4;--accent-active: #7dbdb4;--border: #89B0AE30;--shadow: #00000035;--bubble-self: #3a5c48;--bubble-self-text: #d4ead2;--bubble-other: #2c313b;--bubble-other-text: #e8e8e4}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);line-height:1.6;min-height:100dvh;transition:background var(--transition),color var(--transition)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url(/backgroundsvg/pattern-28.svg);background-size:50%;background-position:center top;opacity:.05;pointer-events:none;z-index:-1}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}.theme-pill{position:fixed;bottom:20px;right:20px;z-index:100;font-size:18px;width:42px;height:42px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);box-shadow:0 2px 8px var(--shadow);display:flex;align-items:center;justify-content:center;cursor:pointer}.main{min-height:100dvh;padding:48px 32px 32px;max-width:640px;margin:0 auto}@media (min-width: 768px){.main{max-width:860px}html{font-size:16px}}.avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:8px}.avatar-img{width:80px;height:80px;border-radius:50%;object-fit:cover;object-position:top;border:2px solid var(--border)}.avatar-name{font-size:15px;font-weight:600;letter-spacing:.04em;color:var(--text)}.avatar-sub{font-size:13px;color:var(--text-muted);letter-spacing:.02em;text-align:center;line-height:1.4}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);font-size:13px;font-weight:500;color:var(--text-muted);transition:background var(--transition),color var(--transition);cursor:pointer;text-decoration:none}.nav-item:hover{background:var(--bg-card-2);color:var(--text)}.nav-item.active{background:var(--accent);color:#fff}html[data-theme=night] .nav-item.active{background:var(--accent);color:var(--bubble-self-text)}.nav-icon{font-size:16px;width:20px;text-align:center}.nav-spacer{flex:1}.theme-toggle{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--radius-md);font-size:12px;color:var(--text-muted);transition:background var(--transition),color var(--transition)}.theme-toggle:hover{background:var(--bg-card-2);color:var(--text)}.bubble-wrap{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}.bubble{max-width:80%;padding:11px 15px;font-size:16px;line-height:1.55;animation:bubble-in .2s cubic-bezier(.23,1,.32,1) both}.bubble.out{align-self:flex-end;background:var(--bubble-self);color:var(--bubble-self-text);border-radius:var(--radius-bubble)}.bubble.in{align-self:flex-start;background:var(--bubble-other);color:var(--bubble-other-text);border-radius:var(--radius-bubble-in);border:1px solid var(--border)}@keyframes bubble-in{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}.tappable{transition:box-shadow .15s ease,border-color .15s ease,opacity .15s ease}.tappable:hover{box-shadow:0 4px 14px var(--shadow)!important}.tappable:active{opacity:.7}.chat-row{display:flex;align-items:flex-start;gap:10px}.chat-avatar-col{flex-shrink:0;padding-top:2px}.chat-avatar{width:44px;height:44px;border-radius:12px;object-fit:cover;object-position:top;border:1px solid var(--border);display:block;cursor:pointer}.chat-bubbles-col{display:flex;flex-direction:column;gap:10px;flex:1;min-width:0}.chat-bubbles-col .bubble{max-width:100%}.nav-bubble{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:500;cursor:pointer;animation:bubble-in .22s cubic-bezier(.23,1,.32,1) both;text-align:left;color:var(--bubble-self-text)}.bubble.out.nav-bubble{border-radius:10px;padding:8px 14px}.nav-bubble-icon{font-size:15px}.cursor{display:inline-block;animation:blink .7s step-end infinite;margin-left:1px;opacity:1}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.bubble-section-label{font-size:15px;font-weight:700;letter-spacing:-.01em;color:var(--bubble-other-text)}.section-header{margin-bottom:20px}.section-title{font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.section-framing{font-size:15px;color:var(--text-muted);margin-top:4px;font-style:italic}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:14px;transition:box-shadow var(--transition)}.card:hover{box-shadow:0 4px 16px var(--shadow);border-bottom:2px solid var(--text)}.timeline-wrap{position:relative;padding:4px 0 12px}.timeline-wrap:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--accent);opacity:.25;transform:translate(-50%)}.timeline-item{display:flex;position:relative;padding:5px 0;align-items:center}.timeline-item.left{justify-content:flex-start;padding-right:calc(50% + 16px)}.timeline-item.right{justify-content:flex-end;padding-left:calc(50% + 16px)}.timeline-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:9px;height:9px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);z-index:2}.timeline-item.left .timeline-dot{left:calc(50% - 16px)}.timeline-item.right .timeline-dot{left:calc(50% + 16px)}.timeline-node{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 9px;display:flex;flex-direction:column;gap:1px;z-index:1}.timeline-item.left .timeline-node{text-align:right;align-items:flex-end}.timeline-item.right .timeline-node{text-align:left;align-items:flex-start}.timeline-item:after{content:"";position:absolute;top:50%;width:16px;height:1px;background:var(--accent);opacity:.35;transform:translateY(-50%)}.timeline-item.left:after{right:50%;width:16px}.timeline-item.right:after{left:50%;width:16px}.snake-company{font-size:10px;font-weight:700;color:var(--accent)}.snake-title{font-size:10px;color:var(--text);font-weight:500;line-height:1.3}.snake-meta{font-size:9px;color:var(--text-muted);margin-top:2px}.impact-section{display:flex;flex-direction:column;gap:12px;margin-top:24px;padding-bottom:16px}.impact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px}.impact-company{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.impact-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.impact-stat{display:flex;flex-direction:column;gap:2px}.impact-value{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.02em;line-height:1}.impact-label{font-size:11px;color:var(--text-muted);line-height:1.3}.impact-notes{font-size:12px;color:var(--text-muted);line-height:1.5;border-top:1px solid var(--border);padding-top:8px;margin-top:2px}.timeline{display:flex;flex-direction:column;gap:0}.timeline-entry{display:flex;gap:14px;position:relative;padding-bottom:24px}.timeline-entry:last-child{padding-bottom:0}.timeline-entry:before{content:"";position:absolute;left:5px;top:20px;bottom:0;width:1px;background:var(--border)}.timeline-entry:last-child:before{display:none}.timeline-dot{width:11px;height:11px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:4px}.timeline-body{flex:1;min-width:0}.timeline-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.timeline-role{display:block;font-size:14px;font-weight:600;color:var(--text);line-height:1.3}.timeline-company{display:block;font-size:12px;color:var(--accent);font-weight:500;margin-top:1px}.timeline-period{font-size:11px;color:var(--text-muted);white-space:nowrap;font-family:var(--font-mono);flex-shrink:0}.timeline-desc{font-size:13px;color:var(--text-muted);margin-top:6px;line-height:1.5}.card-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:2px}.card-meta{font-size:13px;color:var(--text-muted);font-family:var(--font-mono);margin-bottom:8px;letter-spacing:.04em}.card-body{font-size:15px;color:var(--text-muted);line-height:1.6}.photo-masonry{column-count:2;column-gap:8px;margin-bottom:14px}.photo-tile{width:100%;padding:0;border:none;background:var(--bg-card-2);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;display:block;margin:0 0 8px;break-inside:avoid}.photo-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s ease}.photo-tile:hover img{transform:scale(1.04)}.photo-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.photo-lightbox-img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:6px}.photo-lightbox-close{position:absolute;top:16px;right:20px;background:transparent;border:none;color:#fff;font-size:32px;line-height:1;cursor:pointer;padding:4px 10px}.photo-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#fff;font-size:48px;line-height:1;cursor:pointer;padding:8px 16px;opacity:.75}.photo-lightbox-nav:hover{opacity:1}.photo-lightbox-nav.prev{left:8px}.photo-lightbox-nav.next{right:8px}.photo-lightbox-caption{position:absolute;bottom:24px;left:50%;transform:translate(-50%);color:#fff;font-size:13px;opacity:.85}.book-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}.book-tile{display:block;aspect-ratio:2 / 3;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card-2);transition:transform .15s ease,box-shadow .15s ease}.book-tile:hover{transform:none!important;box-shadow:0 4px 16px var(--shadow);border-bottom:2px solid var(--text)}.book-tile img{width:100%;height:100%;object-fit:cover;display:block}.contact-bubble-row{display:inline-flex!important;align-items:center;gap:8px}.contact-bubble{display:inline-block;background:var(--bubble-self)!important;color:var(--bubble-self-text)!important;text-decoration:none;font-weight:500}.contact-bubble:hover{opacity:1;border-bottom:2px solid var(--text)!important}.site-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.site-row{display:block;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;text-decoration:none;transition:border-color .15s ease,transform .15s ease}.site-row:hover{transform:none!important;box-shadow:0 4px 16px var(--shadow);border-bottom:2px solid var(--text)}.site-label{font-size:15px;font-weight:600;color:var(--text)}.site-desc{font-size:14px;color:var(--text-muted);margin-top:2px}.project-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px}.project-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;overflow:hidden;text-align:left;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.project-card:hover{transform:none!important;box-shadow:0 4px 16px var(--shadow);border-bottom:2px solid var(--text)}.project-thumb{aspect-ratio:1 / 1;width:100%;background:var(--bg-card-2);overflow:hidden}.project-thumb img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.1);transform-origin:center;filter:saturate(.65) brightness(.88);transition:filter .25s ease}.project-thumb:hover img{filter:saturate(.85) brightness(1)}.project-info{padding:10px 12px 12px}.project-title{font-size:15px;font-weight:600;color:var(--text);line-height:1.3}.project-tagline{font-size:13px;color:var(--text-muted);margin-top:2px;line-height:1.4}.project-detail-title{font-size:22px;font-weight:700;color:var(--text);line-height:1.2}.project-detail-tagline{font-size:15px;color:var(--text-muted);margin-top:4px}.project-detail-body{font-size:16px;color:var(--text);line-height:1.65;margin-top:16px}.project-detail-divider{border-top:1px solid var(--border);margin:18px 0 14px}.project-detail-features-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:6px}.case-features{margin:4px 0 0;padding-left:20px;color:var(--text);font-size:15px;line-height:1.7}.case-features li{margin-bottom:4px}.project-visit{display:block;text-align:center;margin-top:18px;padding:12px 16px;background:var(--bg-card-2);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);font-size:16px;font-weight:500;text-decoration:none;transition:background .15s ease,border-color .15s ease}.project-visit:hover{background:var(--bg-card);border-color:var(--accent)}.back-link{background:transparent;border:none;color:var(--text-muted);font-size:14px;padding:0 0 10px;cursor:pointer}.back-link:hover{color:var(--text)}.project-detail-thumb{width:100%;background:var(--bg-card-2);border-radius:var(--radius-md, 8px);overflow:hidden;margin-bottom:14px}.project-detail-thumb img{width:100%;height:auto;display:block}.case-section{margin-top:14px}.case-heading{font-size:13px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.case-body{font-size:15px;color:var(--text-muted);line-height:1.6}.resume-list{display:flex;flex-direction:column;gap:18px;margin-top:12px}.resume-entry{display:flex;flex-direction:column;gap:4px}.resume-entry+.resume-entry{border-top:1px dashed var(--border);padding-top:18px}.resume-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.resume-title{font-size:16px;font-weight:600;color:var(--text)}.resume-period{font-size:13px;font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap}.resume-sub{font-size:14px;color:var(--text-muted);margin-bottom:4px}.resume-company{font-weight:500;color:var(--text)}.resume-location{color:var(--text-muted)}.resume-narrative{font-size:15px;color:var(--text-muted);line-height:1.6}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tag{font-size:12px;font-family:var(--font-mono);padding:3px 8px;border-radius:20px;background:var(--bg-card-2);border:1px solid var(--border);color:var(--text-muted);letter-spacing:.03em}.lang-tag{display:inline-flex;align-items:center;gap:6px}.lang-dots{display:flex;gap:3px}.lang-dot{width:6px;height:6px;border-radius:50%;background:var(--border)}.lang-dot.filled{background:var(--accent)}.highlights{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:14px}.highlights li{display:flex;align-items:flex-start;gap:8px;font-size:15px;color:var(--text-muted);line-height:1.55}.highlights li:before{content:"→";color:var(--accent);flex-shrink:0;font-weight:700;margin-top:1px}.contact-item{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border);font-size:14px}.contact-item:last-child{border-bottom:none}.contact-label{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);width:80px;flex-shrink:0;letter-spacing:.04em}.contact-value{color:var(--text);font-weight:500}a.contact-value:hover{color:var(--accent)}.skills-card{padding:24px 12px 18px}.radar-wrap{position:relative;width:100%;max-width:360px;margin:0 auto;aspect-ratio:1 / 1}.radar-svg{width:100%;height:100%;display:block}.radar-ring{fill:none;stroke:var(--border);stroke-width:1}.radar-axis{stroke:var(--border);stroke-width:1}.radar-data{fill:var(--bubble-self);fill-opacity:.55;stroke:var(--accent);stroke-width:1.5;transition:fill-opacity .2s ease,stroke-opacity .2s ease}.radar-data.dim{fill-opacity:.15;stroke-opacity:.35}.radar-point{fill:var(--accent)}.radar-slice{fill-opacity:.35;stroke:none;pointer-events:none}.radar-icon-wrap{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center}.radar-icon{width:38px;height:38px;border-radius:10px;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px var(--shadow);padding:0}.radar-icon svg{display:block}.radar-icon.tappable:hover{transform:none!important;box-shadow:0 4px 14px var(--shadow);border-bottom:2px solid var(--text)}.radar-icon.active{background:var(--bg-card-2);border-color:currentColor;box-shadow:0 0 0 2px var(--bg),0 0 0 3px currentColor}.radar-legend{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:18px}.radar-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--text-muted);background:none;border:none;padding:2px 0;cursor:pointer;transition:color .15s;white-space:nowrap}.radar-legend-item.active{color:var(--text);font-weight:600}.radar-legend-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.radar-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:220px;max-width:220px;font-size:14px;line-height:1.45;padding:10px 12px;z-index:10;pointer-events:none;background:var(--bubble-other);color:var(--bubble-other-text);border:1px solid var(--border);border-radius:var(--radius-bubble-in)}.radar-tooltip-title{font-weight:700;font-size:15px;margin-bottom:4px;color:var(--bubble-other-text)}.skills-divider{height:1px;background:var(--border);margin:18px 0}.skills-hint{text-align:center;font-size:13px;color:var(--text-muted);margin-top:14px;font-style:italic}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:8px;padding:12px 16px 20px;background:var(--bg);z-index:50;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.bottom-nav::-webkit-scrollbar{display:none}@media (max-width: 640px){.bottom-nav{justify-content:flex-start;padding-right:70px}}.bottom-nav-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:10px;font-size:15px;font-weight:500;letter-spacing:.02em;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);transition:background var(--transition),color var(--transition);white-space:nowrap}.bottom-nav-btn.active{background:var(--bubble-self);color:var(--bubble-self-text);border-color:transparent}@media (max-width: 640px){.layout{flex-direction:column}.sidebar{width:100%;height:auto;position:relative;flex-direction:row;flex-wrap:wrap;padding:12px;gap:4px}.avatar-wrap,.nav-spacer{display:none}.main{padding:20px 16px}}@media (min-width: 768px){.bottom-nav-btn{font-size:15px;padding:8px 20px}}.bottom-nav-btn:hover,.bubble.out.nav-bubble:hover{border-bottom:2px solid var(--text)!important}
