*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--page: #0e0e0e;--bg-surface: #111111;--bg-icon: #171717;--bg-icon-hover: #1f1f1f;--text: #b0b0b0;--text-strong: #f0f0f0;--text-muted: #6e6e6e;--border-soft: #1c1c1c;--border-faint: #141414;--border-divider: #181818;--button-bg: #ffffff;--button-text: #0a0a0a;--selection-bg: rgba(255, 255, 255, .12);--surface: var(--page);--surface-low: var(--bg-surface);--surface-container: var(--bg-icon);--surface-high: var(--bg-icon-hover);--on-surface: var(--text-strong);--on-surface-variant: var(--text);--secondary: var(--text-muted);--outline: var(--text-muted);--outline-variant: var(--border-soft);--primary: var(--text-strong);--divider: var(--border-divider);--border-subtle: var(--border-faint);--border-hover: var(--border-soft);--font-sans: -apple-system, "system-ui", "SF Pro Text", "SF Pro Display", "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, "SFMono-Regular", "SF Mono", Menlo, Consolas, monospace;--text-size: 14px;--text-lh: 22px;--footer-size: 13px;--footer-lh: 20px;--display-size: 30px;--display-size-mob: 24px;--radius-sm: 2px;--radius: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-pill: 999px;--space-1: 8px;--space-2: 16px;--space-3: 24px;--space-4: 16px;--space-6: 40px;--space-8: 64px;--space-12: 80px;--gap-heading: 14px;--section-gap: 40px;--section-gap-mobile: 32px;--column-max: 540px;--column-pad: 32px;--ease: cubic-bezier(.22, 1, .36, 1);--dock-ease: cubic-bezier(.16, 1, .3, 1);--dur: .3s}:root[data-theme=light]{--page: #fafafa;--bg-surface: #ffffff;--bg-icon: #f9f9f9;--bg-icon-hover: #efefef;--text: #27272a;--text-strong: #0e0e0e;--text-muted: #9f9f9f;--border-soft: #e4e4e4;--border-faint: #f5f5f5;--border-divider: rgba(0, 0, 0, .08);--button-bg: #0e0e0e;--button-text: #fafafa;--selection-bg: rgba(0, 0, 0, .05)}html{background:var(--page);scroll-behavior:smooth;transition:background-color var(--dur) var(--ease)}body{background:var(--page);color:var(--text);font-family:var(--font-sans);font-size:var(--text-size);line-height:var(--text-lh);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:normal;min-height:100vh;transition:background-color var(--dur) var(--ease),color var(--dur) var(--ease)}#root{min-height:100vh}::selection{background:var(--selection-bg);color:inherit}*{scrollbar-width:thin;scrollbar-color:var(--border-soft) transparent}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-soft);border-radius:var(--radius-pill)}a{color:inherit;text-decoration:none}.column{width:var(--column-max);max-width:calc(100% - (var(--column-pad) * 2));margin:0 auto}.section{padding-top:var(--section-gap)}.section--hero{padding-top:var(--space-12)}.logo-badge{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:var(--radius-md);background:#fff;transition:background-color var(--dur) var(--ease)}.logo-badge img{display:block;width:40px;height:40px;object-fit:contain}:root[data-theme=light] .logo-badge{background:transparent}.divider{height:1px;width:100%;background:var(--border-divider);border:0;margin-top:0;margin-bottom:var(--gap-heading)}.exp-break{margin-top:var(--space-3);margin-bottom:var(--gap-heading)}.label{font-family:var(--font-sans);font-size:var(--text-size);font-weight:400;line-height:var(--text-lh);letter-spacing:normal;text-transform:none;color:var(--text-muted)}.display{font-size:var(--display-size);font-weight:500;line-height:1.25;letter-spacing:-.02em;color:var(--text-strong)}.headline-lg{font-size:var(--text-size);font-weight:400;line-height:var(--text-lh);letter-spacing:normal;color:var(--text-strong)}.body-lg{font-size:var(--text-size);line-height:var(--text-lh);letter-spacing:normal;color:var(--text)}.mono{font-family:var(--font-mono)}.muted{color:var(--text-muted)}@media (max-width: 640px){:root{--section-gap: var(--section-gap-mobile)}.display{font-size:var(--display-size-mob)}}.dock-anchor{position:fixed;left:0;right:0;bottom:max(20px,calc(20px + env(safe-area-inset-bottom,0px)));z-index:100;display:flex;justify-content:center;pointer-events:none}.dock{pointer-events:auto;display:flex;align-items:center;gap:4px;padding:4px;border-radius:var(--radius-pill);background:var(--bg-surface);border:1px solid var(--border-faint);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.dock-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-pill);color:var(--text-strong);background:var(--bg-icon);border:0;cursor:pointer;transition:background-color .42s var(--dock-ease),transform .28s var(--dock-ease)}.dock-btn:hover{background:var(--bg-icon-hover)}.dock-back{flex:none;background:transparent}.dock-back:hover{background:var(--bg-icon-hover)}.theme-toggle{position:fixed;top:max(20px,calc(20px + env(safe-area-inset-top,0px)));right:max(20px,calc(20px + env(safe-area-inset-right,0px)));z-index:100;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-pill);color:var(--text-strong);background:var(--bg-surface);border:1px solid var(--border-faint);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);cursor:pointer;transition:background-color .42s var(--dock-ease)}.theme-toggle:hover{background:var(--bg-icon-hover)}.dock-item{position:relative;display:inline-flex}.dock-tooltip{position:absolute;bottom:calc(100% + 11px);left:50%;transform:translate(-50%) scale(.97);transform-origin:bottom;background:var(--button-bg);color:var(--button-text);white-space:nowrap;pointer-events:none;opacity:0;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500;line-height:18px;transition:transform .15s cubic-bezier(.25,.46,.45,.94),opacity .15s cubic-bezier(.25,.46,.45,.94)}.dock-item:hover .dock-tooltip{opacity:1;transform:translate(-50%) scale(1)}.text-link{position:relative;color:var(--text-strong);display:inline-flex;align-items:center;gap:6px;font-size:var(--text-size);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--text-strong);transition:opacity var(--dur) var(--ease)}.text-link:hover{opacity:.7}.org-link{color:var(--text-strong);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border-soft);transition:text-decoration-color var(--dur) var(--ease),opacity var(--dur) var(--ease)}.org-link:hover{text-decoration-color:var(--text-strong)}.exp-group+.exp-group{margin-top:var(--space-3)}.exp-sublabel{margin-bottom:var(--gap-heading)}.exp-row{padding:10px 0}.exp-head{display:flex;align-items:center;gap:var(--space-2)}.exp-logo{flex:none;width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-icon);border:1px solid var(--border-faint);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;color:var(--text-muted);overflow:hidden}.exp-logo img{width:100%;height:100%;object-fit:cover}.exp-titlewrap{flex:1;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:baseline;gap:6px 16px}.exp-role{font-size:var(--text-size);font-weight:400;line-height:var(--text-lh);color:var(--text-strong)}.exp-date{flex:none;font-family:var(--font-sans);font-size:var(--text-size);color:var(--text-muted);white-space:nowrap;text-align:right}.exp-desc{margin-top:6px;margin-left:calc(36px + var(--space-2));color:var(--text-muted);font-size:var(--text-size);line-height:var(--text-lh)}@media (max-width: 640px){.exp-desc{margin-left:0}.exp-titlewrap{grid-template-columns:minmax(0,1fr);row-gap:2px}.exp-date{text-align:left}}.card-grid{display:flex;flex-direction:column;gap:var(--space-6)}.card{display:block;color:inherit}.card-media{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:var(--radius);overflow:hidden;background:var(--bg-icon);border:1px solid var(--border-faint)}.card-media img,.card-media video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease),opacity var(--dur) var(--ease)}.card:hover .card-media img,.card:hover .card-media video{transform:scale(1.03)}.card-media-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-size);color:var(--text-muted)}.card-body{margin-top:10px}.card-cat{font-size:var(--text-size);color:var(--text-muted)}.card-title{margin-top:4px;font-size:var(--text-size);font-weight:400;line-height:var(--text-lh);color:var(--text-strong);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border-soft);transition:text-decoration-color var(--dur) var(--ease)}.card:hover .card-title{text-decoration-color:var(--text-strong)}.card-sub{margin-top:4px;color:var(--text-muted);font-size:var(--text-size);line-height:var(--text-lh)}.dots-link{display:block;width:fit-content;margin:var(--space-3) 0 0;font-size:var(--text-size);line-height:var(--text-lh);color:var(--text-muted);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border-soft);transition:color var(--dur) var(--ease),text-decoration-color var(--dur) var(--ease)}.dots-link:hover{color:var(--text-strong);text-decoration-color:var(--text-strong)}.proj-count{font-size:var(--text-size);font-weight:400;line-height:var(--text-lh);color:var(--text-muted)}.proj-count sup{font-size:11px;font-weight:400;color:var(--text-muted);margin-left:4px;top:-.6em}.skill-group+.skill-group{margin-top:var(--space-2)}.skill-group-label{margin-bottom:10px}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.pill{font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--text);padding:7px 12px;border-radius:var(--radius-pill);border:1px solid var(--border-faint);background:transparent;transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease),background var(--dur) var(--ease)}.pill:hover{color:var(--text-strong);border-color:var(--border-soft);background:var(--bg-icon)}.music-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.music-card{display:flex;align-items:center;gap:var(--space-2);padding:10px;border-radius:var(--radius);border:1px solid var(--border-faint);background:var(--bg-surface);transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}.music-card:hover{background:var(--bg-icon);border-color:var(--border-soft)}.music-art{flex:none;width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-icon);display:flex;align-items:center;justify-content:center;color:var(--text-muted);overflow:hidden}.music-art img{width:100%;height:100%;object-fit:cover}.music-track{font-weight:400;color:var(--text-strong);font-size:var(--text-size);line-height:var(--text-lh)}.music-artist{color:var(--text-muted);font-size:var(--text-size);line-height:var(--text-lh)}@media (max-width: 540px){.music-grid{grid-template-columns:1fr}}.journey-item{padding:var(--space-2) 0}.journey-stage{font-size:var(--text-size);color:var(--text-muted)}.journey-title{margin-top:4px;font-size:var(--text-size);font-weight:400;line-height:var(--text-lh);color:var(--text-strong)}.journey-body{margin-top:4px;color:var(--text-muted);line-height:var(--text-lh)}.footer{padding-top:var(--section-gap);padding-bottom:max(32px,calc(32px + env(safe-area-inset-bottom,0px)));text-align:center;font-family:var(--font-sans);font-size:var(--footer-size);line-height:var(--footer-lh);color:var(--text-muted)}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}
