:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;--font-size-xs: .8rem;--font-size-xs-lg: .85rem;--font-size-sm: .875rem;--font-size-base-sm: .9rem;--font-size-base-lg: .95rem;--font-size-base: 1rem;--font-size-md-sm: 1.0625rem;--font-size-md: 1.125rem;--font-size-lg: 1.25rem;--font-size-xl-sm: 1.375rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-display: clamp(3rem, 8vw, 5rem);--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root,[data-theme=light]{--bg-primary: #f8f8f8;--bg-stats: #e8e8e8;--text-primary: #1a1a1a;--text-muted: #6b6b6b;--accent: #2563eb;--accent-hover: #1d4ed8;--border: rgba(0, 0, 0, .08);--shadow-card: 0 2px 8px rgba(0, 0, 0, .04), 0 12px 32px rgba(0, 0, 0, .06);--shadow-card-sm: 0 1px 4px rgba(0, 0, 0, .04);--glass-bg: rgba(255, 255, 255, .25);--glass-border: rgba(255, 255, 255, .3);--glass-shadow: 4px 4px 12px 2px rgba(0, 0, 0, .15);--glass-blur: 12px;color-scheme:light;color:var(--text-primary);background-color:transparent}[data-theme=dark]{--bg-primary: #0f0f0f;--bg-stats: #1a1a1a;--text-primary: #f5f5f0;--text-muted: #8a8a85;--accent: #3b82f6;--accent-hover: #60a5fa;--border: rgba(255, 255, 255, .08);--shadow-card: 0 2px 8px rgba(0, 0, 0, .2), 0 12px 32px rgba(0, 0, 0, .25);--shadow-card-sm: 0 1px 4px rgba(0, 0, 0, .15);--glass-bg: rgba(0, 0, 0, .35);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 4px 4px 12px 2px rgba(0, 0, 0, .15);--glass-blur: 12px;color-scheme:dark;color:var(--text-primary);background-color:transparent}[data-theme=accessible]{--bg-primary: #ffffff;--bg-stats: #f0f0f0;--text-primary: #000000;--text-muted: #333333;--accent: #0066cc;--accent-hover: #004499;--border: rgba(0, 0, 0, .2);--shadow-card: none;--shadow-card-sm: none;--glass-bg: transparent;--glass-border: var(--border);--glass-shadow: none;--glass-blur: 0;color-scheme:light;color:var(--text-primary);background-color:transparent}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--bg-primary)}html,body{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}.page{min-height:calc(100vh - 80px)}.page-content{max-width:1200px;margin:0 auto;padding:0 2rem}@media(max-width:768px){.page-content{padding:0 1rem}}.portfolio-header{position:relative;z-index:1000;padding:1rem 0}.portfolio-header.header--pre-aloha{visibility:hidden;pointer-events:none}.portfolio-header.header--intro{opacity:0;animation:header-slide-in .5s ease-out 1.75s forwards}@keyframes header-slide-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.header-inner{display:flex;align-items:center;gap:1rem;width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.header-pill{display:flex;align-items:center;justify-content:flex-start;gap:1rem;flex:1;min-width:0;padding:10px 20px 10px 24px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:9999px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transform:translateZ(0);isolation:isolate}.header-glass{display:flex;align-items:center;gap:1.5rem}.logo{font-weight:var(--font-weight-bold);font-size:var(--font-size-md);color:var(--text-primary);text-decoration:none}.header-menu{display:flex;align-items:center;flex:1;min-width:0;justify-content:flex-end}.nav{display:flex;align-items:center;gap:2rem}.nav-link{font-size:var(--font-size-base-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);text-decoration:none;transition:color .2s}.nav-link:hover{color:color-mix(in srgb,var(--text-primary) 85%,white)}.nav-link.active{color:var(--accent)}.header-mobile-actions{display:none;position:relative;align-items:center;gap:.5rem}.header-menu-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:10px;color:var(--text-primary);cursor:pointer;transition:background .2s}.header-menu-button:hover{background:var(--border)}.header-menu-button[aria-expanded=true]{background:var(--accent);color:#fff}.header-nav-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;padding:6px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:14px;box-shadow:var(--glass-shadow);z-index:100;animation:theme-popover-in .2s ease-out;display:flex;flex-direction:column;gap:2px}.header-nav-menu-link{display:block;padding:10px 14px;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-primary);text-decoration:none;border-radius:10px;transition:background .15s,color .15s}.header-nav-menu-link:hover{background:#0000000f;color:var(--text-primary)}.header-nav-menu-link.active{color:var(--accent);background:#0000000f}[data-theme=dark] .header-nav-menu-link:hover,[data-theme=dark] .header-nav-menu-link.active{background:#ffffff14}.header-nav-menu-theme{margin-top:6px;padding-top:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px}.header-nav-menu-theme-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:6px 14px 4px}@media(max-width:768px){.header-glass .nav,.header-menu{display:none}.header-mobile-actions{display:flex;margin-left:auto}}.theme-toggle-wrapper{position:relative}.theme-toggle{background:none;border:none;cursor:pointer;padding:0}.theme-toggle-track{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:background .2s,box-shadow .2s;transform:translateZ(0);isolation:isolate}.theme-toggle:hover .theme-toggle-track{filter:brightness(1.1);box-shadow:4px 4px 16px 2px #0000002e}.theme-toggle-thumb{display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.theme-popover{min-width:220px;padding:6px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:14px;box-shadow:var(--glass-shadow);z-index:100;animation:theme-popover-in .2s ease-out;isolation:isolate;transform:translateZ(0)}.theme-toggle-wrapper .theme-popover:not(.theme-popover--portal){position:absolute;top:calc(100% + 8px);right:0}.theme-popover--portal{z-index:1001}@keyframes theme-popover-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.theme-popover-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;font-family:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-primary);background:transparent;border:none;border-radius:10px;cursor:pointer;text-align:left;transition:background .15s}.theme-popover-item:hover{background:#0000000f}[data-theme=dark] .theme-popover-item:hover{background:#ffffff14}.theme-popover-item.active{background:#0000000f;color:var(--accent)}[data-theme=dark] .theme-popover-item.active{background:#ffffff14;color:var(--text-primary)}.theme-popover-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit}.theme-popover-label{flex:1}.theme-popover-footer{margin-top:6px;padding-top:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px}.theme-popover-link{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;font-family:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-primary);text-decoration:none;border-radius:10px;transition:background .15s,color .15s}.theme-popover-link:hover{background:#0000000f;color:var(--text-primary)}[data-theme=dark] .theme-popover-link:hover{background:#ffffff14}.site-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;isolation:isolate}.site-bg-layer{--gradient-opacity: 0;--bg-blur: 14px;position:absolute;left:0;top:0;width:100%;height:100%}.site-bg-image{position:absolute;inset:0;width:100%;height:100%;background-image:url(/Background/HawaiiBG_Light.webp);background-size:cover;background-position:center 20%;background-repeat:no-repeat;transform:scale(1.06);filter:blur(var(--bg-blur));transition:filter .6s ease-out}.site-bg--page-transition .site-bg-image{transition-duration:var(--bg-blur-transition-page, .3s)}.site-bg--scroll-driven .site-bg-image{transition-duration:var(--bg-blur-transition-scroll, .15s)}.site-bg--first-reveal .site-bg-image{transition-duration:3.5s}[data-theme=dark] .site-bg-image{background-image:url(/Background/HawaiiBG_Dark.webp)}[data-theme=accessible] .site-bg-image{background-image:none;background-color:var(--bg-primary);filter:none}.site-bg-gradient{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;background:linear-gradient(to bottom,transparent 0%,var(--bg-primary) 100%);opacity:var(--gradient-opacity, 0);transition:opacity .15s ease-out}@media(prefers-reduced-motion:reduce){.site-bg .site-bg-image{transition-duration:.2s}}.page-title-animated{font-size:var(--font-size-display);font-weight:var(--font-weight-bold);letter-spacing:-.03em;line-height:1.05;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);color:var(--text-primary);display:block}.page-title-letter{display:inline-block;animation:page-title-in .8s cubic-bezier(.22,1,.36,1) forwards;opacity:0;filter:blur(8px)}@keyframes page-title-in{to{opacity:1;filter:blur(0)}}@keyframes chip-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.18);opacity:.8}}.chip,.chip-link{backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.chip-dot{display:inline-block;width:10px;height:10px;border-radius:10px;margin-right:8px;animation:chip-pulse 2.4s ease-in-out infinite}.chip-link:hover .chip-hover-text{color:var(--chip-hover-color, var(--accent))!important}.lightbox-backdrop{position:fixed;inset:0;z-index:1100;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:zoom-out;animation:lightbox-backdrop-in .25s ease-out}@keyframes lightbox-backdrop-in{0%{opacity:0}to{opacity:1}}.lightbox-exiting{animation:lightbox-backdrop-out .25s ease-in forwards}.lightbox-exiting .lightbox-content{animation:lightbox-zoom-out .25s ease-in forwards}@keyframes lightbox-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes lightbox-zoom-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}.lightbox-content{max-width:100%;max-height:100%;cursor:default;animation:lightbox-zoom-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes lightbox-zoom-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lightbox-content img{max-width:100%;max-height:calc(100vh - 4rem);width:auto;height:auto;object-fit:contain}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;width:48px;height:48px;font-size:var(--font-size-2xl);line-height:1;color:#fff;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.lightbox-close:hover{background:#fff3}.lightbox-nav{position:absolute;top:0;bottom:0;margin-top:auto;margin-bottom:auto;min-width:64px;height:44px;padding:0 1.25rem;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;color:#fff;background:#ffffff1f;border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.lightbox-nav:hover{background:var(--accent);color:#fff}.lightbox-prev{left:1.5rem}.lightbox-next{right:1.5rem}.lightbox-counter{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);font-size:var(--font-size-base-sm);color:#ffffffb3}.about-polaroid{--base-tilt: calc((var(--stagger, 0) % 8) * 4deg - 14deg);--pin-top: 14px;flex-shrink:0;width:200px;position:relative;display:flex;flex-direction:column;align-items:center;transform-origin:calc(50% + var(--pin-offset-x, 0)) var(--pin-top);transform:scale(.8) rotate(var(--mouse-rotate, 0deg))}.about-polaroid--clickable{padding:0;border:none;background:none;font:inherit;cursor:zoom-in}.about-polaroid-pin{position:absolute;top:calc(var(--pin-top, 14px) - 6px);left:calc(50% + var(--pin-offset-x, 0));transform:translate(-50%);width:12px;height:12px;border-radius:50%;background:linear-gradient(145deg,var(--pin-light) 0%,var(--pin-dark) 100%);box-shadow:inset 0 1px 2px #fff6,0 2px 4px #0000004d,0 0 0 3px #00000014;flex-shrink:0;z-index:2}.about-polaroid-pin[data-pin=red]{--pin-light: #e06666;--pin-dark: #b33d3d}.about-polaroid-pin[data-pin=green]{--pin-light: #4a7c4a;--pin-dark: #2d5a2d}.about-polaroid-pin[data-pin=blue]{--pin-light: #5c7fc7;--pin-dark: #3a5a94}.about-polaroid-pin[data-pin=silver]{--pin-light: #c9c9c9;--pin-dark: #8a8a8a}[data-theme=dark] .about-polaroid-pin{box-shadow:inset 0 1px 2px #ffffff1a,0 2px 4px #00000080}[data-theme=dark] .about-polaroid-pin[data-pin=red]{--pin-light: #b33d3d;--pin-dark: #8b2d2d}[data-theme=dark] .about-polaroid-pin[data-pin=green]{--pin-light: #3a6b3a;--pin-dark: #244424}[data-theme=dark] .about-polaroid-pin[data-pin=blue]{--pin-light: #4a6db5;--pin-dark: #2d4a7a}[data-theme=dark] .about-polaroid-pin[data-pin=silver]{--pin-light: #5a5a5a;--pin-dark: #3a3a3a}.about-polaroid-sway{width:100%;flex-shrink:0;transform-origin:calc(50% + var(--pin-offset-x, 0)) calc(var(--pin-top, 14px) - 10px);margin-top:10px;animation:about-polaroid-wind 6s ease-in-out infinite;animation-delay:calc(var(--stagger, 0) * -.42s)}@keyframes about-polaroid-wind{0%,to{transform:rotate(-2deg)}25%{transform:rotate(1deg)}50%{transform:rotate(2.5deg)}75%{transform:rotate(-1deg)}}.about-polaroid-inner{width:100%;box-sizing:border-box;background:#fff;padding:12px 12px 16px;border-radius:2px;box-shadow:0 4px 6px #00000012,0 10px 24px #0000001f,2px 2px #00000008;transform:rotate(var(--base-tilt));transform-style:preserve-3d;transition:box-shadow .3s ease,transform .2s ease}.about-polaroid:hover .about-polaroid-inner{box-shadow:0 8px 20px #0000001a,0 16px 40px #00000026,3px 3px #0000000a}.about-polaroid-image{width:100%;aspect-ratio:1;overflow:hidden;margin-bottom:6px}.about-polaroid-image img{width:100%;height:100%;object-fit:cover}.about-polaroid-caption{font-family:Georgia,serif;font-size:var(--font-size-base-sm);color:#333;margin:0;text-align:center;font-style:italic;white-space:nowrap;overflow:hidden;min-width:0}[data-theme=dark] .about-polaroid-inner{background:#e5e5e5;box-shadow:0 4px 6px #0000004d,0 10px 20px #0006}[data-theme=dark] .about-polaroid-caption{color:#333}.hero{--hero-content-delay: 0s;position:relative;display:flex;width:100%;aspect-ratio:9 / 6;height:auto;max-height:calc(100vh - 260px);flex-direction:column;align-items:center;justify-content:center;max-width:1200px;margin:0 auto;padding:4rem 2rem}.hero:not(.hero--skip-entrance){--hero-content-delay: 0s}.hero-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-start;height:100%;gap:2rem;width:100%;padding-left:24px;vertical-align:bottom;text-align:left}.hero-intro{position:relative;flex:0 0 auto;min-width:0;width:fit-content;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left}.hero-tags{display:flex;flex-wrap:nowrap;gap:.5rem;margin-bottom:1rem;overflow:visible;width:fit-content}.hero-chip-reveal-frame{display:inline-block;overflow:hidden;height:2.75rem;vertical-align:top}.hero-chip-wrap{display:inline-block;transform:translateY(150%);animation:hero-chip-slide-up .4s cubic-bezier(0,0,.35,1) forwards}@keyframes hero-chip-slide-up{0%{transform:translateY(150%)}to{transform:translateY(0)}}.hero-tags-measure{position:absolute;top:0;left:0;width:fit-content;overflow:visible;opacity:0;display:flex;flex-wrap:nowrap;gap:.5rem;pointer-events:none}.hero-name{margin:0;display:flex;justify-content:flex-start;align-items:center;flex-wrap:wrap;vertical-align:middle;width:fit-content;height:fit-content;padding-top:6px;padding-bottom:6px;font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:var(--font-weight-bold);border-bottom:none}.hero-image{flex:1;display:flex;justify-content:center;align-items:center;min-width:240px;opacity:0;animation:hero-polaroid-fade-in .5s ease-out forwards;animation-delay:calc(.55s + var(--hero-content-delay))}@keyframes hero-polaroid-fade-in{to{opacity:1}}.hero-image .about-polaroid{transform:scale(1.1) rotate(var(--mouse-rotate, 0deg))}.hero-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);margin:0;line-height:1.5;width:fit-content}.hero-subtitle-letter{display:inline-block;opacity:0;filter:blur(8px);animation:page-title-in .8s cubic-bezier(.22,1,.36,1) forwards}.hero-subtitle-part2{opacity:0;animation:hero-subtitle-part2-in .4s ease-out forwards;animation-delay:calc(1.94s + var(--hero-content-delay))}.hero--skip-entrance .hero-chip-wrap,.hero--skip-entrance .hero-subtitle-letter,.hero--skip-entrance .hero-subtitle-part2,.hero--skip-entrance .hero-image{animation:none;opacity:1;transform:none}.hero--skip-entrance .hero-subtitle-letter{filter:none}.hero--skip-entrance .hero-name .page-title-letter{animation:none;opacity:1;filter:none}.hero-aloha-screen{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}.hero-aloha-button{padding:.75rem 2rem;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);font-family:DM Sans,Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:9999px;box-shadow:var(--glass-shadow);cursor:pointer;transition:transform .2s,box-shadow .2s}.hero-aloha-button:hover{transform:scale(1.05);box-shadow:4px 4px 20px #00000026}@keyframes hero-subtitle-part2-in{to{opacity:1}}.hero-title .highlight{color:var(--accent);font-weight:var(--font-weight-semibold)}.hero-word-fade{color:var(--text-primary);font-weight:var(--font-weight-bold)}.hero-word-fade--idle{opacity:1}.hero-word-fade--fading-out{animation:hero-word-fade-out .35s ease-in forwards}.hero-word-fade--fading-in{animation:hero-word-fade-in .35s ease-out forwards}@keyframes hero-word-fade-out{0%{opacity:1}to{opacity:0}}@keyframes hero-word-fade-in{0%{opacity:0}to{opacity:1}}@media(max-width:960px){.hero{aspect-ratio:auto;height:auto;max-height:none;min-height:380px;padding:2rem 1rem;margin-bottom:2.5rem}.hero-content{flex-direction:column;align-items:center;gap:1.5rem;padding-left:0}.hero-intro{text-align:center;align-items:center;width:100%;min-width:0}.hero-tags{justify-content:center;flex-wrap:wrap;width:100%;max-width:100%}.hero-image{min-width:0;width:100%;max-width:280px}}@media(max-width:480px){.hero .hero-chip-wrap:nth-child(n+5){display:none}}.stats-reveal-frame{overflow:hidden;max-width:1200px;margin:0 auto;padding:0 2rem;height:9rem}.stats{max-width:1200px;margin:0 auto;padding:0 0 4rem}.stats--intro{transform:translateY(100%);animation:hero-stats-slide-up .5s ease-out 1.75s forwards}@keyframes hero-stats-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.stats-inline{margin-bottom:3rem}.stats-card{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:24px;padding:12px 24px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transform:translateZ(0);isolation:isolate}.stat-item{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:12px 1.5rem;height:100%}.stat-item:not(:first-child){border-left:1px solid var(--border)}.stat-value{display:flex;flex-direction:column;justify-content:center;align-items:center;vertical-align:middle;height:44px;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:0;transition:transform .1s ease-out}.stat-label{font-size:var(--font-size-base-lg);font-weight:var(--font-weight-normal);color:var(--text-primary)}@media(max-width:768px){.stats{padding:0 1rem 3rem}.stats-card{grid-template-columns:1fr;gap:0}.stat-item{padding:1rem 0}.stat-item:not(:first-child){border-left:none;border-top:1px solid var(--border)}}.key-work{max-width:1200px;margin:0 auto;padding:0 2rem 4rem}.key-work--intro{opacity:0;animation:key-work-fade-in .5s ease-out 1.75s forwards}@keyframes key-work-fade-in{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.key-work-inner{width:100%}.key-work-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.key-work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}@media(max-width:768px){.key-work{padding:0 1rem 3rem}.key-work-grid{grid-template-columns:1fr;gap:1.5rem}}.project-card{display:flex;flex-direction:column;background:none;transition:transform .25s ease;text-decoration:none;color:inherit}.project-card:hover{transform:translateY(-2px)}.project-card:hover .project-title,.project-card:hover .project-tagline{color:var(--accent)}.project-card:hover .project-year{color:var(--accent);opacity:.9}.project-arrow{width:.75em;height:.75em;margin-left:.25em;opacity:0;vertical-align:middle;transition:opacity .2s ease}.project-card:hover .project-arrow{opacity:1}.project-title-text{display:inline-flex;align-items:center}.project-image{aspect-ratio:4 / 3;overflow:hidden;border-radius:16px;border:1px solid var(--border)}.project-image img{width:100%;height:100%;object-fit:cover;display:block}.project-info{padding:1rem 0 0;background:none}.project-title{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 .25rem;transition:color .2s ease}.project-year{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--text-muted);flex-shrink:0;transition:color .2s ease}.project-tagline{font-size:var(--font-size-base-lg);font-weight:var(--font-weight-medium);color:var(--text-muted);margin:0;line-height:1.5;transition:color .2s ease}.case-study{max-width:1200px;margin:0 auto;padding:4rem 2rem}.case-study-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem}.case-study-breadcrumb{font-size:var(--font-size-base-sm);font-weight:var(--font-weight-semibold);color:var(--text-muted);text-decoration:none}.case-study-breadcrumb a{color:var(--accent);text-decoration:none}.case-study-breadcrumb a:hover{text-decoration:underline}.case-study-breadcrumb-sep{margin:0 .5rem;opacity:.6}.case-study-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.case-study-title{margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.case-study-hero-image{margin:0 0 1.5rem;border-radius:44px;overflow:hidden}.case-study-hero-image img{width:100%;height:auto;display:block}.case-study-image-btn{display:block;width:100%;padding:0;border:none;background:none;cursor:zoom-in;text-align:left}.case-study-subtitle{font-size:var(--font-size-xl-sm);font-weight:var(--font-weight-medium);color:var(--text-muted);margin:0 0 2.5rem}.case-study-intro{font-size:var(--font-size-md);line-height:1.7;color:var(--text-primary);margin:0 0 2.5rem}.case-study-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem 3rem;margin-bottom:3rem;padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.case-study-meta dt{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:0 0 .25rem}.case-study-meta dd{font-size:var(--font-size-base);color:var(--text-primary);margin:0}.case-study-section{margin-bottom:2.5rem;opacity:0;transform:translateY(12px);transition:opacity .4s ease-out,transform .4s ease-out}.case-study-section--visible{opacity:1;transform:translateY(0)}.case-study-section-heading{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 1rem}.case-study-section-content p{font-size:var(--font-size-md-sm);line-height:1.75;color:var(--text-primary);margin:0 0 1rem}.case-study-section-content p:last-child{margin-bottom:0}.case-study-section-images{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.case-study-figure{margin:0;border-radius:44px;overflow:hidden}.case-study-figure img{width:100%;height:auto;display:block}.case-study-figure:hover{opacity:.95}.case-study-section-videos{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.case-study-video-wrapper{position:relative;width:100%;padding-bottom:56.25%;border-radius:44px;overflow:hidden}.case-study-video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%}.case-study-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--border)}.case-study-nav-link{font-weight:var(--font-weight-medium);color:var(--accent);text-decoration:none}.case-study-nav-link:hover{text-decoration:underline}@media(max-width:640px){.case-study-meta{grid-template-columns:1fr}}.polaroid-lightbox-backdrop{position:fixed;inset:0;z-index:1100;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:zoom-out;animation:polaroid-lightbox-backdrop-in .25s ease-out}@keyframes polaroid-lightbox-backdrop-in{0%{opacity:0}to{opacity:1}}.polaroid-lightbox-exiting{animation:polaroid-lightbox-backdrop-out .25s ease-in forwards}.polaroid-lightbox-exiting .polaroid-lightbox-content{animation:polaroid-lightbox-zoom-out .25s ease-in forwards}@keyframes polaroid-lightbox-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes polaroid-lightbox-zoom-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}.polaroid-lightbox-content{max-width:100%;max-height:100%;cursor:default;animation:polaroid-lightbox-zoom-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes polaroid-lightbox-zoom-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.polaroid-lightbox-frame{display:flex;flex-direction:column;align-items:center;max-width:min(50vh,calc(100vw - 4rem))}.polaroid-lightbox-inner{background:#fff;padding:20px 20px 56px;border-radius:2px;box-shadow:0 8px 16px #0000001f,0 24px 48px #0003,4px 4px #0000000a}[data-theme=dark] .polaroid-lightbox-inner{background:#2a2a2a;box-shadow:0 8px 16px #0006,0 24px 48px #00000080}.polaroid-lightbox-image{width:min(50vh,calc(100vw - 4rem));height:min(50vh,calc(100vw - 4rem));overflow:hidden;margin-bottom:12px}.polaroid-lightbox-image img{width:100%;height:100%;object-fit:cover;display:block}.polaroid-lightbox-caption{font-family:Georgia,serif;font-size:var(--font-size-md);color:#333;margin:0;text-align:center;font-style:italic}[data-theme=dark] .polaroid-lightbox-caption{color:#e0e0e0}.polaroid-lightbox-close{position:absolute;top:1.5rem;right:1.5rem;width:48px;height:48px;font-size:var(--font-size-2xl);line-height:1;color:#fff;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.polaroid-lightbox-close:hover{background:#fff3}.polaroid-lightbox-nav{position:absolute;top:0;bottom:0;margin-top:auto;margin-bottom:auto;min-width:64px;height:44px;padding:0 1.25rem;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;color:#fff;background:#ffffff1f;border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.polaroid-lightbox-nav:hover{background:var(--accent);color:#fff}.polaroid-lightbox-prev{left:1.5rem}.polaroid-lightbox-next{right:1.5rem}.polaroid-lightbox-counter{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);font-size:var(--font-size-base-sm);color:#ffffffb3}.about-page{padding:3rem 2rem 4rem;overflow-x:visible}.about-content{max-width:1200px;margin:0 auto}.about-page-title{margin-bottom:2rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.about-physics-tuner{display:none;flex-wrap:wrap;gap:1rem 2rem;margin-bottom:2rem;padding:1rem 1.25rem;background:transparent;border-radius:12px}[data-theme=dark] .about-physics-tuner{background:transparent}.about-physics-field{display:flex;flex-direction:column;gap:.25rem}.about-physics-tuner input{width:5rem;padding:.35rem .5rem;font-size:var(--font-size-base-sm);border:1px solid #ddd;border-radius:6px;background:#fff;color:var(--text-primary)}[data-theme=dark] .about-physics-tuner input{border-color:#444;background:#333}.about-physics-label{font-size:var(--font-size-xs-lg);font-weight:var(--font-weight-medium);color:var(--text-muted)}.about-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);color:var(--text-primary)}.about-carousel-section{width:100%;margin-bottom:3rem;overflow-x:visible;overflow-y:visible;padding:4rem 0;display:flex;justify-content:center}.about-carousel-track{--carousel-item-width: 200px;--carousel-gap: 2.5rem;display:flex;align-items:flex-start;gap:var(--carousel-gap);width:max-content;padding-top:8px;position:relative}.about-carousel-section .about-polaroid{opacity:0;transform:scale(1.1) rotate(var(--mouse-rotate, 0deg))}.about-carousel-visible .about-polaroid{animation:about-polaroid-fade-in .5s ease-out forwards;animation-delay:calc(var(--stagger, 0) * .15s)}@keyframes about-polaroid-fade-in{0%{opacity:0;filter:blur(12px)}to{opacity:1;filter:blur(0)}}.about-aloha{margin-bottom:2.5rem}.about-bio{font-size:var(--font-size-md);line-height:1.7;color:var(--text-primary);margin:0 0 1rem}.about-tagline{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--text-primary);margin:0;font-style:italic}.about-contact{margin-bottom:2.5rem}.about-contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem 2rem}.about-contact-item{display:flex;flex-direction:column;gap:.25rem}.about-contact-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-muted)}.about-contact-value{font-size:var(--font-size-base);color:var(--accent);text-decoration:none;transition:color .2s}.about-contact-value:hover{color:var(--accent-hover)}.about-currently{margin-bottom:2.5rem}.about-currently-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.about-currently-card{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:16px;padding:1.25rem;box-shadow:var(--glass-shadow);overflow:hidden;cursor:default}.about-currently-card-inner{display:flex;align-items:center;justify-content:center;max-width:100%}.about-currently-emoji{font-size:var(--font-size-3xl);line-height:1;flex-shrink:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.about-currently-card:hover .about-currently-emoji,.about-currently-card--expanded .about-currently-emoji{transform:translateY(-28px) scale(1.85)}.about-currently-text{position:absolute;left:1.25rem;right:1.25rem;bottom:1.25rem;display:flex;flex-direction:column;gap:0;text-align:center;opacity:0;transform:translateY(10px) scale(.96);transition:opacity .35s cubic-bezier(.34,1.56,.64,1),transform .35s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.about-currently-card:hover .about-currently-text,.about-currently-card--expanded .about-currently-text{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.about-currently-title{font-size:var(--font-size-base-lg);color:var(--text-muted);height:22px}.about-currently-subtitle{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);height:30px;vertical-align:middle}.about-currently-org{font-size:var(--font-size-base-sm);color:var(--text-muted);height:22px}.about-lounge{display:flex;align-items:stretch;gap:1.5rem;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;box-shadow:var(--glass-shadow);overflow:hidden}.about-lounge-image{flex-shrink:0;width:min(36%,280px);border-radius:12px;overflow:hidden;background:transparent}.about-lounge-image img{width:100%;height:100%;object-fit:cover;display:block}.about-lounge-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.75rem}.about-lounge-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0;padding-bottom:.75rem;border-bottom:1px solid var(--border);line-height:1.25}.about-lounge-text{font-size:var(--font-size-md-sm);line-height:1.6;color:var(--text-primary);margin:0}.about-lounge-schedule{font-size:var(--font-size-base);color:var(--text-primary);margin:0}.about-lounge-link{color:var(--accent);font-weight:var(--font-weight-medium);text-decoration:underline;transition:color .2s}.about-lounge-link:hover{color:var(--accent-hover)}@media(max-width:640px){.about-lounge{flex-direction:column}.about-lounge-image{width:100%;max-height:200px}.about-lounge-image img{object-fit:cover}}@media(max-width:768px){.about-contact-grid,.about-currently-grid{grid-template-columns:1fr}}.contact-page{padding:3rem 2rem 4rem}.contact-page .page-title-animated{margin-bottom:2rem}.contact-layout{max-width:52rem}.contact-grid{display:grid;grid-template-columns:repeat(2,minmax(22rem,1fr));gap:1.25rem}.contact-card{display:flex;align-items:flex-start;font-family:Inter,ui-sans-serif,-apple-system,BlinkMacSystemFont,SF Pro,Roboto,Helvetica Neue,Arial,system-ui;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:14px;padding:1rem 1.25rem;text-decoration:none;transition:color .2s,transform .2s ease}.contact-card:hover{transform:scale(1.05)}.contact-card .contact-icon{color:var(--text-muted);transition:color .2s}.contact-card .contact-label,.contact-card .contact-value{transition:color .2s}.contact-card:hover .contact-value{color:var(--accent)}.contact-item-text{display:flex;flex-direction:column;gap:.25rem;min-width:0}.contact-row{display:flex;align-items:center;gap:.5rem}.contact-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.contact-label{font-size:14px;font-weight:600;color:var(--text-muted)}.contact-value{font-size:14px;font-weight:600;color:var(--text-primary)}@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}.resume-page{padding:3rem 2rem 4rem}.resume-page .page-title-animated{margin-bottom:2rem}.resume-placeholder{background:transparent;border-radius:16px;padding:3rem;text-align:center;box-shadow:var(--shadow-card)}.resume-placeholder p{color:var(--text-muted);margin:0 0 1rem}.resume-download{display:inline-block;padding:.75rem 1.5rem;font-weight:var(--font-weight-semibold);color:#fff;background:var(--accent);border-radius:10px;text-decoration:none;transition:background .2s}.resume-download:hover{background:var(--accent-hover)}.design-system-page{padding:3rem 2rem 4rem;max-width:900px;margin:0 auto}.design-system-header{margin-bottom:3rem}.design-system-back{display:inline-block;color:var(--accent);text-decoration:none;font-size:var(--font-size-sm);margin-bottom:1rem;transition:color .2s}.design-system-back:hover{color:var(--accent-hover)}.design-system-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 .5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.design-system-subtitle{font-size:var(--font-size-base);color:var(--text-muted);margin:0 0 1.5rem;line-height:1.6}.design-system-reset{padding:.5rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .2s,border-color .2s}.design-system-reset:hover{background:#e0e0e0;border-color:#00000026}[data-theme=dark] .design-system-reset:hover{background:#252525;border-color:#fff3}[data-theme=accessible] .design-system-reset:hover{background:#e8e8e8;border-color:#00000040}.design-system-theme-tabs{display:flex;gap:.5rem;margin-bottom:2rem}.design-system-tab{padding:.5rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-muted);background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:color .2s,background .2s,border-color .2s}.design-system-tab:hover{color:var(--text-primary);background:#e0e0e0}[data-theme=dark] .design-system-tab:hover{background:#252525}[data-theme=accessible] .design-system-tab:hover{background:#e0e0e0}.design-system-tab.active{color:var(--accent);background:transparent;border-color:var(--accent)}.design-system-grid{display:flex;flex-direction:column;gap:2.5rem}.design-system-section h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.design-system-controls{display:flex;flex-direction:column;gap:1rem}.design-system-control{display:flex;flex-direction:column;gap:.35rem}.design-system-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-muted);font-family:ui-monospace,monospace}.design-system-control input[type=text],.design-system-control input[type=color],.design-system-control select{padding:.5rem .75rem;font-size:var(--font-size-sm);font-family:ui-monospace,monospace;color:var(--text-primary);background:transparent;border:1px solid var(--border);border-radius:6px}.design-system-control input[type=color]{width:48px;height:36px;padding:2px;cursor:pointer}.design-system-input-row{display:flex;align-items:center;gap:.5rem}.design-system-input-row input[type=text]{flex:1}.design-system-shadow-input{min-width:0}.design-system-preview{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}.design-system-preview h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.design-system-preview-card{background:transparent;border-radius:16px;padding:2rem;box-shadow:var(--shadow-card)}.design-system-preview-display{font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 .5rem;line-height:1.1}.design-system-preview-3xl{font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 .5rem}.design-system-preview-lg{font-size:var(--font-size-lg);color:var(--text-primary);margin:0 0 .5rem}.design-system-preview-base{font-size:var(--font-size-base);color:var(--text-primary);margin:0;line-height:1.6}.portfolio-app{min-height:100vh;position:relative}.theme-transition-overlay{position:fixed;inset:0;z-index:9999;pointer-events:none;transition:opacity .4s ease-out}.page-transition-wrapper{transition:opacity .22s ease-out}.page-transition-wrapper.exiting{opacity:0}.page-transition-wrapper.entering{opacity:0;transition-duration:.22s}.page-transition-wrapper.entering.entering-visible{opacity:1}
