@charset "UTF-8";:root{--background: #faf9f7;--background-rgb: 250, 249, 247;--foreground: #2d2d2d;--foreground-rgb: 45, 45, 45;--subdued: #6b6b6b;--muted: #9a9a9a;--border: #e8e6e3;--surface: #f3f1ee;--accent: #5d6e52;--accent-hover: #4a5842;--accent-rgb: 93, 110, 82;--accent-warm: #b8956b;--font-serif: "Libre Baskerville", Georgia, "Times New Roman", serif;--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 2rem;--space-xl: 4rem;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--foreground);background-color:var(--background);cursor:default}#app,#herohi,body,html{min-height:100%}h1,h2,h3,h4,h5,h6{margin:0;font-weight:400}h1{font-family:var(--font-sans);font-size:1.25rem;font-weight:500;line-height:1.3;margin-bottom:var(--space-sm)}h1 a{text-decoration:none;color:var(--foreground);transition:opacity var(--transition-fast)}h1 a:hover{opacity:.7}h1 img{display:block;max-width:80px;margin-bottom:var(--space-sm)}h2{font-family:var(--font-serif);font-size:1.35rem;font-weight:400;line-height:1.3;color:var(--foreground)}h3{font-family:var(--font-sans);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--subdued)}p{margin:0}p+p,h2+p,h3+p,p+ul{margin-top:var(--space-sm)}a{color:var(--foreground);text-decoration-color:rgba(var(--foreground-rgb),.3);text-underline-offset:3px;transition:color var(--transition-fast),text-decoration-color var(--transition-fast)}a:hover{color:var(--accent);text-decoration-color:var(--accent)}.button,button{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-family:var(--font-sans);font-size:1rem;font-weight:500;line-height:1;color:#fff;background-color:var(--accent);border:none;border-radius:6px;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);text-decoration:none}.button:hover,button:hover{background-color:var(--accent-hover);transform:translateY(-1px);text-decoration:none;color:#fff}.button:active,button:active{transform:translateY(0)}.button--outline{background-color:transparent;color:var(--accent);border:1.5px solid var(--accent)}.button--outline:hover{background-color:var(--accent);color:#fff}.wrapper{min-height:100vh;display:flex;flex-direction:column;padding:var(--space-xl) 1.5rem;max-width:900px;margin:0 auto}@media (min-width: 640px){.wrapper{padding:var(--space-xl) var(--space-lg)}}.content{flex:1}header{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}@media (min-width: 640px){header{flex-direction:row;align-items:flex-start}}.col-title{flex-shrink:0}@media (min-width: 640px){.col-title{min-width:200px}}.col-content{flex:1}section{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg) 0}@media (min-width: 640px){section{flex-direction:row}section .col-title{min-width:200px}}hr{border:none;height:1px;background-color:var(--border);margin:0}.hero-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;object-position:center top;border:3px solid var(--surface);box-shadow:0 4px 20px #00000014;margin-bottom:var(--space-md)}@media (min-width: 640px){.hero-photo{width:140px;height:140px}}ul{margin:0;padding:0 0 0 1.5rem;list-style-position:outside}ul li{margin-bottom:var(--space-xs);padding-left:.25rem}ul li+li{margin-top:var(--space-xs)}.text-list{list-style:none;padding:0}.text-list li{padding:var(--space-xs) 0}.intro-lists{display:flex;flex-wrap:wrap;gap:var(--space-xl);margin:var(--space-lg) 0}.intro-lists>div{min-width:150px}.intro-lists h3{margin-bottom:var(--space-sm)}.intro-lists .text-list{font-size:.9rem;color:var(--subdued);line-height:1.7}.projects{list-style:none;padding:0;border-top:1px solid var(--border);counter-reset:project}.projects li{display:flex;flex-direction:column;padding:var(--space-md) 0;border-bottom:1px solid var(--border);gap:var(--space-xs)}@media (min-width: 640px){.projects li{flex-direction:row;justify-content:space-between;align-items:baseline}}.projects li:before{counter-increment:project;content:counter(project,decimal-leading-zero);font-size:.75rem;color:var(--muted);margin-right:var(--space-md)}.projects .title{flex:1}.projects .description{color:var(--subdued);font-size:.875rem}.subdued{color:var(--subdued)}.small{font-size:.875rem}.mono{font-family:DM Sans,monospace;font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border);font-size:.875rem;color:var(--subdued)}::selection{background-color:var(--accent);color:#fff}.cta-section{background-color:var(--surface);padding:var(--space-lg);border-radius:8px;margin:var(--space-md) 0}.cta-section p{margin-bottom:var(--space-md)}.theme-toggle{display:none}.isDarkMode{display:none!important}.isClearMode{display:block}input:not([type=radio]),textarea{padding:.75rem 1rem;font-family:var(--font-sans);font-size:1rem;color:var(--foreground);background:var(--surface);border:1px solid var(--border);border-radius:6px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:not([type=radio]):focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}input:not([type=radio])::placeholder,textarea::placeholder{color:var(--muted)}textarea{min-height:120px;resize:vertical}.site-header[data-v-5c1fbef9]{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}@media (min-width: 640px){.site-header[data-v-5c1fbef9]{flex-direction:row;align-items:flex-start;justify-content:space-between}}.header-left[data-v-5c1fbef9]{flex-shrink:0}.logo-link[data-v-5c1fbef9]{display:block;text-decoration:none}.logo[data-v-5c1fbef9]{width:70px;margin-bottom:.75rem}h1[data-v-5c1fbef9]{font-family:var(--font-sans);font-size:1.1rem;font-weight:500;color:var(--foreground);margin:0}.header-right[data-v-5c1fbef9]{flex:1;max-width:400px}.hero-photo[data-v-5c1fbef9]{width:100px;height:100px;border-radius:50%;object-fit:cover;object-position:center 20%;margin-bottom:1rem;border:3px solid var(--surface, #f3f1ee);box-shadow:0 4px 16px #00000014}@media (min-width: 640px){.hero-photo[data-v-5c1fbef9]{width:120px;height:120px}}.tagline[data-v-5c1fbef9]{font-size:1rem;line-height:1.6;color:var(--foreground);margin:0 0 .5rem}.baseline[data-v-5c1fbef9]{margin:0}
